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The DP8490 and DP5380 
Comparison Guide 



OVERVIEW 

National Semiconductor has released two products to sup- 
port the Small Computer System Interface (SCSI). These 
two products offer significant features over existing asyn- 
chronous SCSI devices such as: 

• Lower power (25 mW vs 700 mW) 

• Lower cost 

• Higher speed (up to 4 Mbytes/sec) 

• More functionality 

• Compatibility (with existing NCR5380) 
FEATURES OF NATIONAL'S DP8490 & DP5380 

Low Power 

The DP8490 Enhanced Asynchronous SCSI Interface 
(EASI) and the DP5380 Asynchronous SCSI Interface (ASI) 
are CMOS devices. The current drawn by the NCR5380 is 
140 mA while both the EASI and the ASI draw 4 mA max— 
and the EASI/ASI are specified with SCSI pins terminated 
with SCSI spec values! 

Low Cost 

National's marketing strategy will ensure the EASI and ASI 
are the most competitively priced parts on the marl<et. 

High Speed 

The high speed CMOS process used for the EASI and ASI 
means that DMA rates of up to 4 Mbytes per second are 
achievable. Currently there are no low cost high speed 8-bit 
DMA controllers that will provide the necessary speed. A 
common solution is to provide the simple DMA functionality 
as part of ASIC circuitry normally found in each application. 
National has published an application note on how to build a 
4 Mbytes/sec asynchronous SCSI interface using the EASI/ 
ASI devices to assist designers. 

The user should be aware that with this increase in speed 
comes the need and care on the user's part in board design 
and layout. The EASI and ASI have reduced: read access 
times from 140 ns to 50 ns, write data hold times from 30 ns 
to 10 ns, and all other parameters correspondingly. This 
means the designer should ensure he has correctly generat- 
ed chip strobes. In particular pay attention to the generation 
of DACK, and the period of hand-over of the bus between 
the DMA and CPU. 

Improved Functionality 

The EASI provides new and enhanced functions to ease the 
firmware overhead. The major features are: 

new interrupts 

new interrupt status and masl< structure 

extended arbitration 

loopback and other testing facilities 

microprocessor data bus parity 

improved SCSI and DMA timing 

New Interrupts 

The EASI adds interrupts for: arbitration complete, any 
phase mismatch, true end of DMA and microprocessor pari- 
ty error. The arbitration complete interrupt allows the firm- 
ware to program the EASI to arbitrate for the bus and inter- 
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rupt when done. True End of DMA interrupt overcomes the 
fault in the DP5380 when using it to sertddata on SCSI. 

New Interrupt Structure 

The DP5380 cannot be fully interrupt driven (e.g., no arbitra- 
tion complete intermpt)— the DP8490 can be! In the 
DP5380 the firmware must read 2 registers and then pro- 
cess the results to determine the cause of an interrupt. Not 
all interrupt conditions have a status bit in the DP5380. The 
DP8490 provides an inten-upt status register which gathers 
all status into one register, with a dedicated status bit for 
each interrupt. An interrupt mask register provides individual 
masking control of each interrupt. Finally, the design of the 
interrupt logic ensures interrupts will not be lost (they can be 
on the DP5380). 

Extended Arbitration 

The DP5380 device must be polled by the ftP during arbitra- 
tion. Since this process does not start until the bus is free, 
the fiP may be polling for many milliseconds. The DP8490 
provides an inten-upt on arbitration complete to allow the jtP 
to handle other tasks such as cacheing data, overlapped 
seeks etc. The DP8490 also implements the 2.2 jts SCSI 
arbitration delay before interrupting the juP. 

Loopback Testing 

The DP8490 provides a loopback test mode. Each SCSI pin 
driver is disabled and looped back internally. The firmware 
may exercise the EASI to verify correct part operation. SCSI 
signal driving and monitoring, interrupts and DMA can all be 
tested. The EASI also provides programmable parity polarity 
(EVEN/ODD) for both juP and SCSI buses. These bits may 
be used to verify parity circuitry on all boards in a SCSI 
system. 

Microprocessor Parity 

The PCC-packaged DP8490 provides an extra pin for fiP 
data bus parity. This enables checked data to be maintained 
throughout a system— even including controller buffer mem- 
ory. 

Improved Timing 

The DP5380 has some timing anomalies just like the 
NCR5380 on the SCSI and jaP interfaces. The DP8490 fixes 
these. 

COMPATIBILITY 

The DP5380 is completely compatible with existing 
NCR5380 type devices— but offers higher speed and lower 
power. 

The DP8490 is also completely compatible with existing 
NCR5380 type devices except for one register bit. An un- 
used "test-mode" bit in the NCR5380 is replaced by an 
"Enhanced Mode" bit in the DP8490. Until this bit is set the 
DP8490 functions as a DP5380. Once set the enhanced 
features of the DP8490 are accessible. Since the DP8490 
powers up in DP5380 mode all DP53B0 sockets should be 
able to use a DP8490I 

For more information see Section 8 of the DP8490 data- 
sheet. 
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General Description 

The DP8490 EASI is a CMOS device designed to provide a 
low cost, higt) performance Small Computer Systems Inter- 
face. It complies with the ANS X3.131-1986 SCSI standard 
as defined by the ANSI X3T9.2 committee. It can act as 
both INITIATOR and TARGET, making it suitable for any 
application. The EASI supports selection, reselection, arbi- 
tration and all other bus phases. High-cun-ent open-drain 
drivers on chip reduce application chip count by interfacing 
direct to the SCSI bus. An on-chip oscillator provides all 
timing delays. 

The DP8490 is pin and program compatible with the NMOS 
NCR5380 and CMOS DP5380 devices. NCR5380, DP5380 
or AM5380 applications should be able to use it with no 
changes to hardware or software. The DP8490 includes 
new features which mal<e this part more attractive for new 
designs and performance upgrades. These new features in- 
clude fiP data bus parity, programmable parity for both SCSI 
and /U.P busses, loopback test mode, improved artaitration 
support, faster timing and extended intermpt control logic. 
The DP8490 is available in a 40-pin DIP or a 44-pin PCC. 
The EASI is intended to be used in a microprocessor based 
application, and achieves maximum performance with a 
DMA controller. The device is controlled by reading and 
writing several internal registers. A standard non-multi- 
plexed address and data bus easily fits any iiP environment. 
Data transfers can be performed by programmed-l/0, pseu- 
do-DMA or via a DMA controller. The EASI easily Interfaces 
to a DMA controller using normal or Block Mode. The 



EASI can be used in either a polled or interrupt-driven envi- 
ronment. The EASI includes enhanced features for interrupt 
control. 

Features 

SCSI Interface 

■ Supports TARGET and INITIATOR roles 

■ Parity generation with optional checking 

■ Programmable parity polarity (ODD/EVEN) 

■ Arbitration support— can inten-upt when done 

■ Direct control/monitoring of all SCSI signals 

■ High current outputs drive SCSI bus directly 

■ Faster and improved timing 

■ Very low SCSI bus loading 

jxP Interface 

■ Memory or l/0-mapped control transfers 

■ Programmed-l/0 or DMA data transfers 

■ Normal or Block-mode DMA 

■ Fast DMA handshake timing 

■ Individually maskable interrupts 

■ Active interrupts identified in one register 

■ Optional data bus parity generation/checking 

■ Programmable parity polarity (ODD/EVEN) 

■ Loopback test mode 



Connection Diagram 
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1.0 Functional Description 



1.1 OVERVIEW 

The EASI is designed to be used as a peripiieral device in a 
fiP-based application and appears as a number of read/ 
write registers. Write registers are programmed to select de- 
sired functions. Status registers provide Indication of operat- 
ing conditions, in an application extensive use of Inten-upts 
is desirable. The EASI Incorporates an Improved interrupt 
structure which enables fully interrupt-driven operation. In 
the enhanced mode Interrupts can be Individually masked or 
enabled, and a status register Identifies all active Interrupt 
requests. 

For best performance a DMA controller can be easily inter- 
faced directly to the EASI. The EASI provides request/ac- 
knowledge and wait-state signals for the DMA interface. 
The SCSI bus is easily controlled via the EASI registers. Any 
bus signal may be asserted or deasserted via a bit in the 
appropriate register, and the state of every signal is avail- 
able by reading registers. This direct control over SCSI sig- 
nals allows the user to Implement all or part of the protocol 
in firmware. The EASI provides hardware support for much 
of the protocol, and all speed-critical steps are handled by 
the EASI. 
The EASI provides the following SCSI support: 

• Programmed-l/0 transfers for all eight information trans- 
fer types, with or without parity. 

• Data transfers via DMA, in either block or non-block 
mode. The DMA interface supports most devices. 

• Individual setting/resetting and monitoring of every SCSI 
bus signal. 

• Automatic release of the bus for BSY loss from a TAR- 
GET, SCSI RST, and lost arbitration. 

• Automatic bus arbitration with an optional interrupt upon 
completion — the )nP has only to check for highest priori- 
ty. The 2.2 )xs artiitratlon delay can be optionally per- 
formed by the EASI. 



• Selection or Reselection of any bus device. The EASI will 
respond to both Selection and Reselection. 

• Optional automatic monitoring of the BSY signal from a 
TARGET with an interrupt after releasing control of the 
bus. 

• Optional parity polarity selection. Default after reset Is 
ODD, but EVEN generation and checking can be pro- 
grammed for diagnostic purposes and to determine 
whether a device supports parity when first making a 
connection. 

Figure 1 shows an EASI in a typical application, a low cost 
embedded SCSI disk controller. In this application the 8051 
single-chip jiiP acts as the controller and the dual DMA 
channels in the DP8475 allow one for the disk data and the 
other for SCSI data. The PAL provides chip selection as well 
as determining who has control of the bus. The advantage 
of using a jiP with on-board ROM Is that there is more free 
time on the external bus. 

1.2 fxP INTERFACE 

Figure 2 shows a block diagram of the EASI. Key blocks 
within the EASI are Read/Write registers with associated 
decode and control logic, interrupt and DMA logic, SCSI bus 
arbitration logic, SCSI drivers/receivers with parity and the 
SCSI data Input and output registers. The EASI has three 
interfaces, one to SCSI, one to a DMA controller and the 
third to a /tP. The internal registers control all operation of 
the EASI. 

The jxP interface consists of non-multiplexed address and 
data busses with associated control signals. The data bus 
can be programmed to use either ODD or EVEN parity. Ad- 
dress decode logic selects a register for reading or writing. 
The address lines A0-A2 select the register for ;*P access- 
es while for DMA accesses the address lines are ignored. 
The decode logic also selects different registers or func- 
tions to be mapped Into address 7, according to the pro- 
grammed mode (see Section 8). 
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1.0 Functional Description (continued) 
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FIGURE 2. EASI Block Diagram 



The register bank consists of twelve registers mapped into 
an address space of eight locations. Upon an external chip 
reset the registers are cleared (all zeroes) — the same as the 
NCR5380. Once the ENHANCED MODE bit in the INITIA- 
TOR COMMAND REGISTER Is set, three new registers can 
be accessed to utilize the extra features of the DP8490 
EASI. 

1.3 DMA INTERFACE 

The DMA logic Interfaces to single-cycle, block mode, flow- 
through or fly-by controll ers. Sin gle byte transfers are ac- 
complished via the DRQ/DACK handshake signals. Block 
mode transfers use the READY output to co ntroi the speed 
(Insert wait-states). An End Of Process (EOP) Input from the 
DMA controller signals the EASI to halt DMA transfers. An 
intermpt can be generated for DMA completion or an error 
(see Section 5). All DMA data passes through the SCSI data 
Input and output registers, automatically selected during 
DMA cycles. 

1.4 SCSI INTERFACE 

The EASI contains all logic required to Interface directly to 
the SCSI bus. Direct control and monitoring of all SCSI sig- 
nals Is provided. The state of each SCSI signal may be de- 
termined by reading a register which continuously reflects 
the state of the bus. Each signal may be asserted by writing 
a ONE to the appropriate bit. 

The EASI includes logic to automatically handle SCSI timing 
sequences too fast for fi.P control. In particular there Is 
hardware support for DMA transfers, bu s arb itration, selec- 
tion/reselection, bus phase monitoring, BSY monitoring for 
bus disconnection, bus reset and parity generation and 
checking. 



The EASI arbitration logic controls arbitration for use of the 
SCSI bus. The jiP programs the SCSI device ID Into the 
EASI, then sets the ARBITRATE bit. The EASI will Interrupt 
the (xP when one of three events occurs: arbitration Is lost; 
arbitration has completed and the ID priorities need to be 
checked; or arbitration Is complete and the 2.2 jus SCSI 
Arbitration delay has expired. Arbitration can be Invoked 
with the enhanced feature of an Interrupt on completion or 
the expiration of the SCSI Arbitration delay. These extra 
steps are programmed via the EXTRA MODE REGISTER 
(EMR). The INITIATOR COMMAND REGISTER (ICR) is 
read to detennine whether arbitration has been won or lost. 
The BSY signal Is continuously monitored to detect bus dis- 
connection and bus free phases. The EASI incorporates an 
on-board oscillator to determine Bus Settle, Bus Free and 
Arbitration Delays. The oscillator tolerance guarantees all 
timing to be within the SCSI specification. 
The EASI Incorporates high-current drivers and SCHMITT 
trigger receivers for Interfacing directly to the SCSI bus. This 
feature reduces the chip count of any SCSI application. The 
driver/receivers also incorporate loopback logic which Is 
enabled by an EMR bit. The Loopback mode enables test- 
ing of all EASI functions without Interfering with the SCSI 
bus. 

1.5 PARITY 

The EASI provides for parity protection on both the /xP and 
SCSI interfaces. Each data bus has eight data bits and one 
parity bit (only the PCC part provides iiP parity, both the DIP 
and PCC provide SCSI parity). In each case the parity may 
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1.0 Functional Description (continued) 

be enabled via a register bit. A parity error can be pro- Interrupt. In ENHANCED MODE two registers are used to 
grammed to cause an interoipt. Additionally the parity may control intermpts— the INT STATUS REGISTER (ISR) and 
be programmed to be either ODD or EVEN. This has a par- the INT MASK REGISTER (IMR). Each interrupt can be 
ticular use on the SCSI interface where programming EVEN masked from interrupting via the IMR. When an internjpt is 
parity allows diagnostics, or determining whether a device recognized by the jxP, reading the ISR will display all active 
supports parity. The inclusion of /iP parity allows develop- inten-upt sources. The ISR contents remain unchanged until 
ment of controllers that maintain data integrity right from the an interrupt reset is programmed. A shadow register behind 
media to the host system. the ISR guarantees that interrupts occurring while others 
1.6 INTERRUPTS ^^ serviced will not be lost. 

The EASI is intended to be used in an inten^ipt-driven envi- 
ronment. Each function can be programmed to cause an 

2.0 Pin Descriptions 


Symbol 


DIP 


PCC 


Type 


Function 


C§ 


21 


24 


1 


Chip Select: an active low enable for read or write operations, accessing 
the register selected by A0-A2. 


A0-A2 


30,32 
33 


33,36 
37 


1 


Address 0-2: these three signals are used with CS, RD, and WR to address 
a register for read or write. 


RD 


24 


27 


1 


Read: an active low enable for reading an internal register selected by 
A0-A2 and enabled by CS. It also selects the Input Data Register when 
used with DACk. 


VVR 


29 


32 


1 


Write: an active low enable for writing an Internal register selected by 
A0-A2 and enabled by CS. It also selects the Output Data Register when 
used with DACK. 


RESET 


28 


31 


1 


Reset an active low input with a Schmitt trigger. Clears all internal registers. 
(SCSI R§T unaffected.) 


D0-D7, P 


1,40-34 


2, 44-38 
1 


I/O 


Data 0-7, P: bidirectional TRI-STATE® signals connecfing the active high 
)aP data bus to the internal registers. The PCC part offers an optionai parity 
on the /xP data bus. If the parity option is not enabled the pin is TRi-STATE. 


INT 


23 


26 


O 


Interrupt: an active high output to the ftP when an en-or has oocun^d, an 
event requires service or has completed. 


DRQ 


22 


25 


o 


DMA Request: an active high output asserted when the data register Is 
ready to be read or written. DRQ occurs only If DMA mode is enabled. The 
signal is cleared by DACK. 


DACK 


26 


29 


1 


DMA Aclcnowledge: an active low input that resets DRQ and addresses the 
data registers for input or output transfers. DACK is used instead of 5§ by 
the DMA controller. 


READY 


25 


28 





Ready: an active high output used to control the speed of block mode DMA 
transfers. Ready goes active when the chip is ready to send/receive data 
and remains inactive after the transfer until the byte Is sent or until the DMA 
mode bit is reset. 


eGp 


27 


30 


1 


End of Process: an active low signal that terminates a block of DMA 
transfers. It should be asserted during the transfer of the last byte. 


DB0-DB7 
DBP 


9-2,10 


10-3,11 


I/O 


DB0-DB7, DBP: SCSI data bus with parity. DB7 is the MSB and Is the 
highest priority during ariaitration. Parity is default ODD but can be 
programmed EVEN. Parity is always generated and can be optionally 
checked. Parity is not valid during arbitration. 


RST 


16 


18 


I/O 


Reset: SCSI reset, monitored and can be set by EASI. 


BSY 


13 


15 


I/O 


Busy: indicates the SCSI bus is being used. Can be driven by TARGET or 
INITIATOR. 
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2.0 Pin Descriptions (Continued) 



Symbol 



DIP 



PCC 



Type 



Function 



SEL 



12 



14 



I/O 



Select: used by the INITIATOR to select a TARGET or by the TARGET to 
reselect an INITIATOR. 



ACK 



14 



16 



I/O 



Acknowledge: driven by the INITIATOR and received by the TARGET as 

part of the REQ/ACK handshake. ■ 



ATN 



15 



17 



I/O 



Attention: driven by the INITIATOR to indicate an attention condition to the 
TARGET. 



REQ 



20 



22 



I/O 



Request: driven by the TARGET and received by the INITIATOR as part of 

the REQ/ACK handshake. 



I/O 



17 



19 



I/O 



Input/Output: driven by the TARGET to control the direction of transfers on 
the SCSI bus. This signal also distinguishes between selection and 
reselection. 



C/D 



18 



20 



I/O 



Command/Data: driven by the TARGET to indicate whether command or 
data bytes are being transferred. 



MSG 



19 



21 



I/O 



Message: driven by the TARGET during message phase to identify 
message bytes on the bus. 



Vcc 

GND 



31 
11 



35 
12,13 



Vcc. QND: + 5 Vdc is required. Because of very large switching currents, 
good decoupling and power distribution is mandatory. 



2.1 Connection Diagrams 
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3.0 Register Description 

3.1 GENERAL 

The DP8490 EASI is a register-based device withi eiglit ad- 
dressable locations used to access twelve registers. Some 
addresses have dual functions depending upon whether 
they are being read from or written to. Two basic operating 
"modes" result in differences in the registers accessed 
through address 7. Device operation is described in Section 
4 but mode differences are highlighted in this section and 
Section 8. 

The EASI operates in one of two modes— NORMAL (MODE 
N) and ENHANCED (MODE E). Switching between the 
modes is performed by setting or resetting bit 6 in the Initia- 
tor Command Register. 

In MODE N, EASI registers appear the same as the 
DP5380. In MODE E, address 7 accesses enhanced logic 
features. To help identify these differences the register de- 
scription is split into two subsections. The first describes the 
registers in MODE N. The second describes the register 
differences when in MODE E. 

Figure 3. 1 summarizes the register map in MODE N. Note 
that for registers reading or writing SCSI signals the SCSI 
name is used for each bit. Although the SCSI bus is active 
low, the registers invert the SCSI bus. This means an active 
SCSI signal is represented by a ONE in a register and an 
inactive signal by a ZERO. 



Hex 
Adr 


Register 


Mnemonic 


Bits 


R/W 






Output Data Register 
Current SCSI Data 


ODR 
CSD 


8 
8 


WO 

RO 


1 

2 
3 

4 
4 


Initiator Command Register 
Mode Register 2 
Target Command Register 
Select Enable Register 
Current SCSI Bus Status 


ICR 
MR2 
TCR 
SER 
CSB 


8 
8 
4 
8 
8 


RW 
RW 
RW 
WO 
RO 


5 


Bus and Status 


BSR 


8 


RO 


5 


Start DMA Send 


SDS 





WO 


6 
6 
7 


Start DMA Target Receive 

Input Data Register 

Start DMA Initiator Receive 


SDT 
IDR 
SDI 



8 



WO 
RO 
WO 


7 


Reset Parity/Interrupts 


RPI 





RO 



FIGURE 3.1. Normal Mode Registers 

3.2 NORMAL MODE REGISTERS 

OUTPUT DATA REGISTER (ODR) 
8 Bits HA Write Only 

This is a transparent latch used to send data to the SCSI 
bus. The register can be written by /tP cycles or via DMA. 
DMA writes automatically select the ODR at Hex Address 
(HA 0). This register is also written with the ID bits required 
during arbitration and selection/reselection phases. Data is 
latched at the end of the write cycle. 

Bit? BitO 



CURRENT SCSi DATA (CSD) 
8 Bits HA Read Oniy 

This register enables reading of the current SCSI data bus. 
If SCSI parity checking is enabled it will be checked at the 
beginning of the read cycle. The register is also used for fiP 
accesses of SCSI data during programmed-l/0 or ID check- 
ing during arbitration. Parity is not valid during arbitration. 
DMA transfers select the IDR (HA 6) instead of the CSD 
register. 



Bit? 



BitO 



DB7 


DB6 


DBS 


DB4 


DBS 


DB2 


DB1 


DBO 



Current SCSi Data 

iNITIATOR COMMAND REGISTER (ICR) 

8 Bits HA 1 Read/Write 

This register is used to control the INITIATOR and some 
other SCSI signals, and to monitor the progress of bus arbi- 
tration. Most of the SCSI signals may als o be asserted in 
TARGET mode. Bits 5 to are reset when BSY is lost (see 
MR2 description). 

Bit? BitO 



RST 


AlP/ 
MODE 


LA/ 
DIFF 


ACK 


BSY 


SEL 


ATN 


DBUS 



DB7 


DB6 


DBS 


DB4 


DBS 


DB2 


DBT 


DBO 



Output Data Register 



initiator Command Register 
DBUS: Assert Data Bus Bit 

Disable SCSI data bus driving. 

1 Enable contents of Output Data Register onto the 
SCSI data bus. SCSI parity is also generated and driv- 
en on DBP. 

This bit should be set when transferring data out of the EASI 
in either TARGET or INITIATOR mode, for both DMA or 
programmed-l/O. In INITIATOR mode the drivers are only 
enabled if: Mode Register 2 TA RGET MODE bit is 0, and 
I/O is false, and C/D, I/O, MSG match the contents of the 
Target Command Register (phasematch is true), in TAR- 
GET mode only the MR2 bit needs to be set with this bit 
Reading the ICR reflects the state of this bit. 
ATN: Assert Attention Bit 1 

Deassert ATN 

1 Assert SCSI ATN signal. The MR2 TARGET MODE bit 
must also be false to assert the signal. 

Reading the ICR reflects the state of this bit. 
SEL Assert Select Bit 2 

Deassert SEL 

1 Assert SCSI SEE signal. Can be used in INITIATOR or 
TARGET mode. 

Reading the ICR reflects the state of this bit. 
BSY: Assert Busy Bit 3 

Deassert BSY. 

1 Assert SCSI BSY signal. Can be used in INITIATOR or 
TARGET mode. 

Reading the ICR reflects the state of this bit. 
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3.0 Register Description (continued) 

ACK: Assert Acknowledge Bit 4 

Deassert ACK. 

1 Assert SCSI ACK signal. The MR2 TARGET MODE bit 
must also be false to assert the signal. 

Reading the ICR reflects the state of this bit. 
DIFF: Differential Enable Bits Write 
This bit must be reset to 0. 
LA: Lost Arbitration Bit 5 Read 

Normally reset to to show arbitration not lost or not 
enabled. 

1 Will be set when the EASI loses arbitration, i. e. wh en 
SEL Is true during arbitration AND the Assert SEL bit 
of this register is false. 

A 1 in th is bit means the EASI has arbitrated for the bus, 
asserted BSY and its ID on the data bus and another device 
has asserted SEL. The ARBITRATE bit in MR2 or the EMR 
must be set to enable arbitration. 
MODE: Operating Mode Bit 6 Write 

Normal Mode (MODE N) is selected. 

1 Enhanced Mode (MODE E) is selected. 
AlP: Arbitration in Progress Bit 6 Read 

Normally to show no arbitration In progress. 

1 Set when the EASI has detected BUS FREE phase 
and asserted BSY and the Output Data Register con- 
tents onto the SCSI data bus. This bit remains set until 
arbitration is disabled. 

RST: Assert RST Bit 7 

Deassert RST. 

1 Assert SCSI RST signal. RST is asserte d as long as 
this bit is 1 , or until a jaP Reset (RESET). 

After this bit Is set the INT pin goes active and internal regis- 
ters are reset (except for the interrupt latch, MR2 TARGET 
MODE bit, and this bit). Reading the ICR reflects the state of 
this bit. 

MODE REGISTER 2 (MR2) 

8 BiU HA 2 Read/Write 

This register is used to program basic operating conditions 
in the EASI. Operation as TARGET or INITIATOR, DMA 
mode and type as well as some interrupt controls are set via 
this register. This is a read/write register and when read the 
value reflects the state of each bit. 



DMA: DMA Mode 



Bill 



Bit? 














BitO 


BLK 


TARG 


PCHK 


PINT 


EOP 


BSY 


DMA 


ARB 



ARB: Arbitrate 



Mode Register 2 
BitO 



Disable arbitration 

1 Enable arbitration. The EASI will wait for a BUS FREE 
phase then arbitrate for the bus. Before setting this bit 
the Output Data Register should contain the SCSI de- 
vice ID--a single bit set only. The status of the arbitra- 
tion process is given In the AlP and LA bits (6,5) in the 
Initiator Command Register. 



Disable DMA mode 



1 Enable DMA operation. This bit should be set then one 
of address 5 to 7 written to start DMA. The TARGET 
MODE bit In the ICR and the phase lines in the TCR 
should have been set appropriately. The DBUS bit in 
the ICR must be set for DMA send operations. BSY 
must be active in order to set this bit The phase lines 
must match the contents of the TCR during the actual 
transfers . In DMA m ode EASI logic automatically con- 
trols the REQ/ACK handshakes. 
This bit shou ld be reset by a jj.P write to stop any DMA 
transfer. An E OP sign al will not reset this bit. During 
DMA, CS and DACK should not be active simulta- 
neously. 
This bit will be reset if BSY Is lost during DMA mode. 

BSY: Monitor Busy Bit 2 

Disable BSY monitor. 

1 Monitor SCSI BSY signal and interrupt when BSY goes 
inactive. When this bit goes active the lower 6 bits of 
the ICR are reset and all signals removed from the 
SCSI bus. This is used to check for valid TARGET 
connection. 

EOP: Enable EOP interrupt Bit 3 

No interrupt for EOP. 

1 Interrupt after valid EOP condition. 
PINT: Enable SCSI Parity interrupt Bit 4 

No Inten'upt on SCSI parity en-or. 

1 When SCSI parity is enabled via the PCHK bit, setting 
this bit enables an inten-upt upon a SCSI parity error. 

PCHK: Enable SCSI Parity Checking Bit 5 

No SCSI parity checking. 

1 Enable checking of SCSI parity during read operations. 
This applies to either programmed I/O or DMA mode. 

TARG: Target Mode Bit 6 

Initiator Mode 

1 Target Mode 

BLK: Block Mode DMA Bit 7 

Non-block DMA 

1 When set along with DMA bit (1), enables block mode 
DMA transfers. In block mode the READY line is used 
to handshake each byte w ith the DMA controller In- 
stead of the DRQ/DACK handshake used in non- 
block mode. 

TARGET COMMAND REGISTER (TCR) 
4 Bits HA 3 Read/Write 

This register Is used to control TARGET SCSI signals and to 
program the desired phase during INI TIATOR mode. D uring 
DMA transfers the SCSI phase lines (C/D, MSG, I/O) must 
match the contents of the TCR for transfers to occur. A 
phase mismatch halts DMA transfers and generates an in- 
ten-upt. 
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Target Command Register 
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3.0 Register Description (continued) 

This is a read/write register and the value read reflects the 
state of each bit, except bits 4-7 which always read 0. 
175: Assert 175 Bit 

Deassert I7C 

1 Assert SCSI i70 signal. The l\/IR2 TARGET MODE bit 
must also be active. 

CTD: Assert C7d Bit 1 

Deassert C/D 

1 Assert SCSI C7D signal. The MR2 TARGET MODE bit 
must also be active. 

MSG: Assert MSG Bit 2 

Deassert MSG. 

1 Assert SCSI MSG signal. The MR2 TARGET MODE bit 
must also be active. 

REQ: Assert REQ Bit 3 

Deassert REQ. 

1 Assert SCSI REQ signal. The MR2 TARGET MODE bit 
must also be active. This bit is used to handshal<e 
SCSI data via programmed-l/O. 

SELECT ENABLE REGiSTER (SER) 
8 Bits HA 4 Write Oniy 

This write-only register is used to program the SCSI device 
ID for the EASI to respond to during Selection or Reselec- 
tion phases. Only one bit in the register should be set. When 
SEE is true, BSY false and the SER ID bit active an interrupt 
will occur. 

This interrupt is reset or can be disabled by writing zero to 
this register. Parity will also be checked during Selection or 
Reselection If the PCHK bit in MR2 is set. 



Bit 7 



BitO 



DB7 
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DBS 


DB4 


DB3 


DB2 


DB1 


DBS 



Select Enable Register 
CURRENT SCSi BUS STATUS (CSB) 
8 Bits HA 4 Readonly 

This read-only register is used to monitor SCSI control sig- 
nals and the SCSI parity bit. The SCSI lines are monitored 
during programmed-l/O transfers and after an interrupt in 
order to determine the cause. A bit is 1 if the corresponding 
SCSI signal is active. 
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SEE 
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Current SCSi Bus Status 
BUS AND STATUS REGiSTER (BSR) 
8 Bits HA 5 Read Only 

This read-only register is used to monitor SCSI signals not 
included in the CSB, and internal status bits. This register is 
read after an interrupt (in MODE N) to determine the cause 
of an interrupt. Bit or 1 are set to 1 if the SCSI signal is 
active. 



ACK: Acicnowiedge Bit 

This bit reflects the state of the SCSI ACK Signal. 
ATN: Attention Bit 1 
This bit reflects the state of the SCSI ATN Signal. 
BSY: Busy Error Bit 2 

No error 

1 The SCSI BSY sig nal ha s become inactive while the 
MR2 B§Y (Monitor BSY) bit is set. This will cause an 
inten-upt, remove all EASI signals from the SCSI bus 
and reset the DMA MODE bit in MR2. 

PHSM: Phase Match Bit 3 

Phase Match. The SCSI C7d, 175 and MSG phase 
lines are continuously compared with the con-espond- 
ing bits in the TCR. The result of this comparison is 
reflected in this bit. This bit must be 1 (phase matches) 
for DMA transfers. A phase mismatch will stop DMA 
transfers and cause an interrupt. 

i'. f: interrupt Request Bit 4 

No interrupt 

1 Interrupt request active. Set when an enabled interrupt 
condition occurs. This bit reflects the state of the INT 
pin. INT may be reset by performing a Reset Parity/In- 
terrupt (RPI) function. 

SPER: SCSI Parity Error Bit 5 

No SCSI parity en-or 

1 SCSI parity error occun-ed. This bit remains set once 
an error occurs until the RPI function clears it. The 
PCHK bit in MR2 must be set for a parity error to be 
checl<ed and registered. 

DRO: DMA Request Bit 6 

No DMA request 

1 DMA request active. This bit reflects the sla te of the 
DRO pin. DRQ is reset by asserting DACK during a 
DMA cycle or by resetting the DMA bit in MR2. A Busy 
error will reset the MR2 DMA bit and thus will also 
clear DRQ. A phase mismatch will not reset DRQ. 

EDMA: End of DMA Bit 7 



Not end of DMA 



1 Set when DACK, EOP and either RD or WR are active 
simultaneously. Normally occurs when the last byte Is 
transferred by the DMA. During DMA send operations 
the last byte transferred by the D MA may not have 
been transferred on SCSI so RE5 and ACK should be 
monitored to verify when the last SCSI transfer is com- 
plete. This bit is reset when the MR2 DMA bit is reset. 

Note: In MODE E the EASI presents a true EDMA bit in bit 7 of the TCR, 
This feature removes the need to poll the REQ and A5K signals. 

START DMA SEND (SDS) 
Bits HA S Write Only 

This write-only register is used to start a DMA send opera- 
tion. A write of don't care data should be the last thing done 
by the 11.P. The MR2 DMA, BLK and TARG bits must have 
been programmed previously. 
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3.0 Register Description (continued) 

START DMA TARGET RECEIVE 
Bits HA 6 Write Only 

This write-only register is used to start a DMA Target Re- 
ceive operation. Same comments as SDS apply. 

INPUT DATA REGISTER (IDR) 

8 Bits HA 6 Read Only 

Tliis read-only register contains the SCSI data last latched 
during a DMA receive. Each byte from SCSI is latched into 
this r egister automatically by the EASI DMA logic. A DMA 
read (PACK and RD) automatically selects this register. Pro- 
grammed I/O SCSI data reads should use the CSD (HA 8). 

START DMA INITIATOR RECEIVE (SDI) 
Bits HA 7 Write Only 

This write-only register is used to start DMA INITIATOR Re- 
ceive Operation. Same comments as SDS apply. An alter- 
native method of performing the SDI function is available in 
the Enhanced Mode Register. 

RESET PARITY/INTERRUPT (RPI) 
Bits HA 7 Read Only 

This read-only register is used to reset the parity and inter- 
rupt latches. Reading this register resets the SCSI parity, jxP 
parity, Busy Loss and Interrupt Request latches. It also re- 
sets the inten-upt latches presented in the Inten-upt Status 
Register (available in MODE E). 

An alternative method of performing the Reset Parity Inter- 
rupt function is available in the Enhanced Mode Register. In 
MODE E writing a value of 01 to bits 2 and 1 of the EMR will 
reset the same bits as a read from HA 7 in MODE N. The 
EMR RPI will also reset enhanced logic that has bits set in 
the Internjpt Status Register. 

3.3 ENHANCED MODE REGISTERS 

Addresses to 6 remain the same as MODE N except for 
bit 7 of TCR, as described below. Address 7 is the SDI and 
RPI functions in MODE N, but in MODE E it directly access- 
es the Enhanced Mode Register (EMR) and indirectly ac- 
cesses the Interrupt Masl< Register (IMR) and the Interrupt 
Status Register (ISR). 

When bit 6 in the ICR (HA 1) is set, HA 7 accesses the 
read/write EMR. The SDI and RPI functions performed 
when writing/reading HA 7 in MODE N are disabled. To 
perform these functions the EMR is used instead. 
Note that EMR functions are intended to be used in an inter- 
rupt-driven environment. Reading this register reflects the 
state of each bit. 

TARGET COMMAND REGISTER (TCR) 
5 Bits HA 3 Read/Write 

This is the same as MODE N except for bit 7 which is de- 
scribed below. Note bits 4-6 always read 0. 
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EDMA: True End of DMA Bit 7 

Not End of DMA 

1 Set when the last byt e of d ata has b een transferred. 
This bit is not set until REQ and ACR^oth go inactive 
following the DMA cycle during which EOP was assert- 
ed. Note that unlike the BSR EDMA bit, this bit reflects 
the true completion of DMA transfers. 

ENHANCED MODE REGISTER (EMR) 

8 Bits HA 7 Read/Write 

This register is accessed at HA 7 when the ICR MODE bit 
(6) is set. The register controls operation of enhanced logic 
and timing. Normally the application will leave the EASI per- 
manently in MODE N or MODE E. 
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Target Command Register 



Enhanced Mode Register 

ARB: Extended Arbitration Bit 

Disable extended arbitration 

1 Enable extended arbitration. This is an alternative bit 
to the MR2 ARB function. The EASI waits for a BUS 
FREE phase then arbitrates for the bus, asserting the 
content s of the ODR onto the SCSI data bus and as- 
serting BSY. The EASI will then wait the 2.2 jxs SCSI 
Arbitration Delay, and set the Arbitration Complete bit 
in the ISR and cause an interrupt. As for the MR2 ARB 
function, the ICR LA and AlP bit can be examined to 
determine arbitration status. 

EFN1,0: Enhanced Function Bits 2,1 

00 No operation— these bits ALWAYS read 00. 

01 When this pattern is written the Parity and internjpt 
latches are reset This pattern should be followed by 
any other pattern to remove the reset (usually 00). 
This function replaces the RPI function performed 
when reading HA 7 in MODE N. Only the latches with 
ISR bits set to 1 will be reset. 

10 Start DMA Initiator Receive. At the end of the write 
cycle the SDI function is performed. There is no need 
to follow with another pattern as required with the RPI 
value (01). This function replaces the SDI function per- 
formed when writing HA 7 in MODE N. 

1 1 Read/Write ISR/IMR. When this pattern is written the 
NEXT read of HA 7 will access the ISR, or the NEXT 
write to HA 7 will access the IMR. This state ONLY 
lasts for the ONE following read OR write cycle. Fur- 
ther cycles will then access the EMR. 

LOOP: Loopbaci( Mode Bit 3 

Normal operation 

1 When set: SCSI drivers are disabled and the SCSI 
l/O's looped back inside the EASI, and both the TAR- 
GET and INITIATOR signals may be driven simulta- 
neously. This enables the jiP to check EASI operation 
without affecting the SCSI bus. 

SPOL: SCSI Parity Polarity Bit 4 

SCSI parity is ODD (as per SCSI specification). 

1 SCSI parity is EVEN. This allows diagnostics to be per- 
formed. 
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3.0 Register Description (continued) 

MPOL: juP Parity Polarity Bit 5 

ixP parity Is ODD. 

1 jiP parity is EVEN. 

MPEN: iiP Parity Enable Bit 6 

iiP parity checl<ing and generation disabled. 

1 Enable checking of juP data bus parity during |u,P and 
DMA writes. Generate parity during /xP and DMA 
reads. Parity en-ors will cause an Interrupt and set the 
ISR MPE bit if not masked. 

APHS: Any Phase Mismatch Bit 7 

Disable phase mismatch detection 

1 Detect SCSI reque sts with a phase mismatch present. 
Is set when RIQ goes active AND the SCSI phase 
lines do not match the contents of the TCR. Can be 
used in INITIATOR mode to interrupt on TARGET 
phase changes. 

INTERRUPT STATUS REGISTER (iSR) 
8 Bits HA 7 (EFN = 11) Read Only 

This register is accessed during the first read cycle after the 
EFN bits in the EMR have both been set to 1 . Once read, 
successive accesses of HA 7 go to the EMR. This register 
provides all interrupt status within one register. This is in- 
tended to make determination of interrupt sources easier in 
MODE E. In MODE N two registers must be read— the BSR 
and CSB. In MODE E only the ISR needs to be read. Addi- 
tionally each inten-upt (except SCSI RST) has a correspond- 
ing status bit in the ISR. 

When the ISR is read all unmasked, enabled, active Inter- 
rupt sources set their corresponding ISR bits to a ONE. The 
interrupt status is sampled at the beginning of the ISR read 
cycle. When an RPI function is performed via the EMR, only 
each interrupt latch with an ISR bit set will be reset. This 
means interrupts occurring since the last ISR read will not 
be lost. 

ISR bits may be individually masked via their corresponding 
bits in the IMR. 



Bit 7 



BitO 



SPE I MPE |eDMA DPHS APHS _BSY_ SEL ARB | 

interrupt Status Register 

ARB: Arbitration Complete Bit 

This bit is set when arbitration enabled by EMR ARB bit (0) 
has completed. Completion occurs in two ways: when the 
EASI loses arbitration and has asserted the LA bit in the 
ICR; or when the EASI has assert ed the ID contained in the 
ODR onto the data bus, asserted BS¥, then waited for the 
2.2 JU.S SCSI Arbitration Delay. 

SEL: Selectlon/Reseiectlon Bit 

This bit is set when B§Y is false, SEU is active, and any SER 
bit set to 1 has an active corresponding SCSI data bus bits. 
This situation occurs during Selection or Reselection phas- 
es. 

BSY: Busy Loss Bit 2 

This bit is the same as BSR bit 2. Set when the SCSI S§Y 
signal becomes inactive while the MR2 BSY (monitor B§Y) 
bit is set 



APHS: Any Phase Mismatch Bit 3 
Set when a REG occurs while the SCSI phase lines do not 
match. Bit is set to enable detection of the contents of the 
TCR. EMR APHS (bit 7) must be 1 to allow this bit to be set. 
DPHS: DMA Phase Mismatch Bit 4 
Set when a SCSI DMA mode operation occurs with a phase 
mismatch. Similar to the APHS condition but restricted to 
DMA mode only. In MODE N this condition is not as easily 
determined. 

EDMA: End of DMA Bit 5 

Set when REQ and ACK are both false following the DMA 
cycle during which E5p was asserted. This represents the 
true end of DMA operation. 
MPE: |aP Parity Error Bit 6 

Set when /xP parity error is detected at the end of a ^iP or 
DMA write cycle. The MPEN bit in the EMR must be set for 
liP parity to be checked. 
SPE: SCSI Parity Error Bit 7 
Set when a SCSI parity en-or is detected when reading the 
CSD, during selection/reselection, or when the IDR is load- 
ed during DMA operation. The MR2 PCHK bit must be set 
for SCSI parity to be checked, and the MR2 PINT bit must 
be set to enable the interrupt. 

INTERRUPT MASK REGISTER (IMR) 

8 Bits HA 7 (EFN =11) Write Only 

This register is accessed during the first write cycle after the 
EFN bits in the EMR have been set to 11 . Once written, 
successive reads or writes at HA 7 access the EMR. 
This register has the same bit definition as the ISR. If a bit in 
the IMR is set to 1 that interrupt will be masked. The inter- 
rupt will be captured internally (if enabled) but will not cause 
an active INT signal. A bit reset to will enable that inten-upt 
to occur (if enabled) and will enable the ISR bit to be set to 
1. 
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interrupt Mask Register 

4.0 Device Operation 

4.1 GENERAL 

This section describes overall operation of the EASI. More 
detailed information of data transfers, interrupts and reset 
conditions are covered in later sections. The operation de- 
scription covers fiP accesses, SCSI bus monitoring, arbitra- 
tion, selection, reselection, programmed-l/O, DMA inter- 
rupts. Programming and timing details are covered. 
For information regarding interfacing to juPs and DMA con- 
trollers refer to Section 9. 

In the descriptions following, program examples are given in 
pseudo-C. This processor-independent approach should be 
clearest. These are backed up by flow charts in Appendix 
A1. 

For each section where appropriate the description is split 
into two, MODE N and MODE E. 
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4.0 Device Operation (continued) 
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FIGURE 4.2. fiP Cycles 



4.2 ^P ACCESSES 

The jiP accesses the EASI via the CS, RD, WR and address 
and data lines In order to read/write the registers. Figure 4. 1 
shows typlcai tinning. Note the use of non-muitiplexed ad- 
dress and data lines. 

4.3 SCSI BUS MONITORING/DRIVING 

The SCSI bus may be monitored or driven at any time. Each 
bus signal is buffered and inverted by the EASI and can t>e 
read via the CSB, BSR and CSD registers. An active SCSI 
signal reads a 1 in the status registers. 
Each SCSI signal may be asserted by setting a bit in the 
TCR or ICR. Setting the bit to 1 asserts the SCSI signal. 
The folloviring code demonstrates a byte transferred via pro- 
grammed-l/O in INITIATOR mode. 

{ /* Transfer one byte as Initiator */ 
while (NOT (ICR: REQ) ) ; 
/* wait till TARGET asserts REQ */ 
data = input (CSD) ; 
/* parity is checked if enabled */ 
output (ICR, Assert_ACK) ; 

while (TCR:REQ) ; 

/* wait till TARGET deasserts RIQ */ 
output (ICR, 0) ; 

/* deassert ACK, ready for next byte »/ 
) 

4.4 ARBITRATION 

This sub-section describes the arbitration support provided 
by the EASI and how to program It. 

4.4.1 MODE N Arbitration 

Since the SCSI arbitration process requires signal sequenc- 
ing too fast for juPs, hardware support is provided by the 
EASI. The arbitration process is enabled by bit MR2 
(ARB). Prior to setting this bit the ODR should be pro- 
grammed with the device's SCSI ID— a single bit. 
The EASI will monitor the bus for a BUS FREE phase. The 
BSY signal is continuously monitored. If continuousl y ina c- 
tive for at least a SCSI Bus Settle Delay (400 ns) and SEC is 
inactive, a valid Bus Free Phase exists. After a perio d of 
SCSI Bus Free Delay (800 ns) the EASI asserts BSV and 
the ODR onto the SCSI data bus. The ^P should poll the 
ICR to determine when arbitration has started. The AlP bit in 
the ICR is set when the Bus Free Phase is detected and the 



EASI is beginning the Bus Free Delay. Following the Bus 
Free Delay a 2.2 (j,s SCSI Arbitration Delay isrequired be- 
fore examining the data bus to resolve the priorities of the 
ID bits. This delay must be implemented in firmware. The 
ICR Lost Arbitration (LA) bit must be examined to determine 
whether arbitration is lost. The LA bit is set if another device 
asserts §EL during arbitration. If the LA bit is the data bus 
is read via the CSD register. The data is examined to re- 
solve ID priorities. If this device is the highest ID, assert SEL 
by setting ICR bit 2 to a 1. After waiting Bus Clear + Bus 
Settle Delays (1200 ns), the Selection Phase begins. These 
2 delays must be implemented in firmware. 

4.4.2 MODE E Arbitration 

The extended arbitration in MODE E is enabled by bit of 
the EMR (ARB). This alternative offers two significant ad- 
vantages over MODE N. First the 2.2 )xs SCSI Arbitration 
Delay is implemented by the EASI. Second the arbitration 
process may be interrupt driven. 

In MODE N the EASI must be polled to see when the ICR 
AlP bit is set. After the appropriate delays, the LA bit and 
data bus are examined. If arbitration is lost or this device is 
not the highest priority the MR2 ARB bit must be reset to 0, 
then set to 1 again and the whole process restarted. This 
means the EASI MUST be polled until arbitration is won— 
potentially many SECONDS, typically ms. This ties up the 
host fiP. 

In MODE E when the EMR ARB bit is set the EASI will: wait 
for BUS FREE phase; delay SCSI Bus Free Delay; assert 
BSY and the ODR onto DB0-BB7; delay SCSI Arbitration 
Delay; interrupt the fiP. 

The fiP should read the ISR and if the ISR bit (ARB com- 
plete) is set examine ICR bits 5 and 6 (LA and AlP) to deter- 
mine whether arbitration is lost. If not lost the data bus is 
examined to resolve ID priorities. As for MODE N if arbitra- 
tion has failed the EMR ARB bit should be reset and then 
set again after first resetting the ARB interrupt. Note that the 
EMR ARB bit allows the jiP to cany on with other tasks 
while the EASI arbitrates. This means there is NO NEED to 
poll the EASI. 

4.5 SELECTION/RESELECTiON 

The EASI can be used to select or reselect a device. The 
EASI will also respond to selection or reselection. Selecting 
or reselecting a device Is the same in MODE N or MODE E. 
Response to selection or reselection can differ between the 

bus modes. 
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4.0 Device Operation (continued) 

4.5.1 Selecting/Reselecting 

Selection requires programming the ODR with the desired 
and own devic e IDs; the data bus via ICR DBUS (bit 0); 
asserting ATN If required via ICR bit 1; asserting SEL via 
ICR bit 2; then resetting the MR2/EMR ARB bit. 
The SER should have been cleared to zero before Selec- 
tion/ Reselection to ensure the EASI does not respond. If 
Resele ction is desired the l70 line should also be asserted 
before SEL via TCR bit 0. 

Resetting the ARB bit causes the EASI to remove BSY and 
the ODR from the data bus. Thus the ICR Assert data bus 
bit Is required to assert the bits for desired and own device 
IDs. 

BSY Is then monitored to determine when the device has 
responded to (re)selection. If the device falls to respond an 
error handler should sequence the EASI off the bus. If the 
device responds the ICR DBUS and SEL bits should be re- 
sett o remove these signals. If this Is a Reselection the ICR 
BSY bit (3) should be set before removing the other signals. 

The bus Is now ready to handle Information Transfer Phas- 
es. 

4.5.2 MODE N (Re)Selection Response 

The EASI responds to Selection or Reselection when the 
SER Is non-zero. A (re)selected interrupt is generated when 
BSY Is false for at least a Bus Settle Delay (400 ns); and 
SEL is true AND any non-zero bit in the SER has its corre- 
sponding SCSI data bus bit active. A Selection is disabled 
by zeroing the SER. If parity is supported it should be valid 
during (re)selectlon so it must be checked via the SPE bit 
(5) In the BSR. SCSI specification states that (re)selectlon is 
not valid If more than 2 data bits are active. This condition is 
checked by reading the CSD. 

When the selection interrupt occurs it Is determined by read- 
ing the BSR and CSB registers. There is no dedicated 
status bit for (re)selection in MODE N, it must be determined 
by the absence of other internipts, and the active state of 
the SEL signal. Reselection occurs when I/O Is also active. 
See Section 6. 

4.5.3 MODE E (Re)Selectlon Response 

The same conditions for valid (re)selection apply as for 
MODE N. A (re)selectlon interrupt is generated as per 
MODE N. The difference is that the Interrupt sets the SEL 
bit (1) In the ISR. In MODE E, reading the ISR enables exact 
determination of Intermpt sources. This inten-upt can be 
masked via bit 1 of the IMR. The intemjpt is reset by pro- 
gramming the RPI function to the EMR. See Section 6 for 
further details. 

4.6 MONITORING BSY 

While an INITIATOR Is connected to a TARGET the TAR- 
GET must main tain an active BSY signal. During DMA oper- 
ations the BSY signal is monitored by the EASI and will halt 
operations If It goes inactive. To enable BSY to be moni- 
tored at other times the MR2 BSY bit (2) should be set An 
Interrupt will be generated if BSY goes inactive while MR2 
BSY Is set. 

In MODE N this Interrupt sets bit 2 In the BSR. In MODE E 
this Interrupt sets bit 2 In the BSR and bit 2 in the ISR. The 
Intermpt may be masked via bit 2 of the IMR. 

4.7 COMMAND/MESSAGE/STATUS TRANSFERS 

Command, message and stat us by tes are transferred using 
programmed-l/0. The SCSI Req/aCK handshake is ac- 



complished by monitoring and setting lines individually. Data 
is output via the ODR and read In via the CSD register. 
The following code shows INITIATOR and TARGET pro- 
gramming for two of these cases. See Appendix A1 for flow- 
charts. 

Initiator Command Send 

( 

MR2 = monitor BSY 

ICR = Command Phase /* 02h */ 

while (bytes) to do) ( 

while (REQ) inactive) 

idle; /* CSB bit 5 = */ 
if (BSE: phase_matoh=0) 
phase error ; 
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else 



ODR = data byte; 

ICE = Assert_ACK; 

while (EEQ active) 

idle; /* CSB bit 5==1 */ 

ICR = deassert_ACK 

/* byte transfer complete »/ 

byte count - - ; 



goto data phase ; 

1 

Target Message Receive 

{ 

/* assumed Assert_BSY already set in ICE «/ 
MR2 = lARG MODE OR PARITY CHECK 

OR PAEIIY IHIEERUPI; 
TCR = Message.Out phase ; /* 06h */ 
delay (Bus Settle) ; 
ICR = Assert_REQ ; 
while (ACic inactive) 

idle; /* BSR bit */ 
data = CSD; /* parity is latched */ 
if (BSR: parity.error) 

error routine ; 
else f 

ICR = deassert.REQ ; 
while (ASc active) 
idle; 
) 
/* message done, can change to next 
phase*/ 
) 

4.8 NON-BLOCK DMA TRANSFERS 

Data transfers may be effected by DMA. This method 
should be used for optimum performance. Two methods of 
DMA are available — block and non-block mode. This sec- 
tion describes non-block mode transfers. MODE N opera- 
tion is covered first followed by MODE E. 
The Interface to the DMA controller uses the DRQ, DACK, 
EOP lines I n non-b lock mode. Each byte Is requested (DRQ) 
and ack'd (DACiK). Representative timing for a DMA read Is 
shown in Figura 4.8. 1. 
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4.0 Device Operation (continued) 
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FIGURE 4.8.1. Non-Block DMA Timing 



4.8.1 MODE N Non-Block DMA 

DMA operation involves programming the EASI with the set- 
up parameters, initiating the DMA cycles and checking for 
correct operation when the completion interrupt is received. 
The DMA controller should be programmed with the data 
byte count and the memory start address. Methods of halt- 
ing a DMA operation are covered In Section 4.11. 
Setting up the EASI requires enabling or dis abling the fol- 
lowi ng: D ata bus driving, DMA mode enable, BSY monitor- 
ing, EOP inten-upt, parity checking, parity interrupt, TARGET 
Mode, bus phase. 

Once set up, DMA should be Initiated by writing to address 
5, 6 or 7 as appropriate. The DMA controller should assert 
iSP during the transfer of the last byte, although this may 
be done by the jxP if the DMA transfers (n- 1) bytes and the 
fiP transfers the last byte. See the application guide for 
more details (Section 9). 

Upon completion the jxP should check the following as re- 
quired: End of DMA, Parity Error, Phase Match, Busy Error. 
In MODE N the end of DMA occurs as a res pon se to EOP. 
SCSI transfers may still be underway so REG and ACK must 
still be checked to establish when the final byte is finished. 
The code below shows programming of the EASI In each of 
the four DMA cases. One of these cases Is shown in a flow 
diagram In Appendix A. 

Initiator Send /* DAIA OUT PHASE */ 
( 

Program DMA Controller; 

ICR = OOh; /* phase */ 

/* Assert_DBUS */ 



ICR = Olh; 
UR2 = OEh; 
SDS = 00; 



/* Start DMA Send */ 



while (NOT interrupt) 

idle; 
while (CSD:Rl^) 

idle; /* wait for last SCSI byte 
transfer so phase 
is checked */ 
if(BSR:Busy_error OR NOT(BSR:End_of_DMA) ) 

error routine ; 
else I /* DMA END */ 

MR2 = 04h; /* reset DMA bit */ 

ICR = ; 



Initiator Receive /* DAIA IB PHASE */ 
I 
Program DMA Controller; 
ICR = Olh; /* phase */ 
MR2 = 3Eh; 

SDI = ; /* Start DMA Init Rx */ 
while (NOI interrupt) 

idle ; 
/* no need to wait for last SCSI handshake 
done since DMA done implies it is 
checked */ 
if (BSR:parity_error OR BSR:busy .error 
or NOI (BSR End of DMA) ) 
do error routines ; 
else ( /* End of DMA */ 

while (CSD:REQ) 

idle ; /* wait for REQ inactive 
to deassert ACK */ 
MR2 = 04h; 



Target Receive /* DATA OUT PHASE */ 
f 
Program DMA controller; 
ICR = 0; /*phase*/ 
ICR = 08h; 

MR2 = 7Ah; /*oheck parity*/ 
SDI = 0; /*Start DMA larg Rx*/ 
while (not interrupt) 

idle ; 
/♦when End of DMA occurs the last byte 

has been read and checked*/ 
if(BSR:parity-error OR NOT(BSR:End_of_DMA) 

error routine ; 
else ( /* End of DMA */ 
while (BSRiACK) 

idle; 
/♦Not True End of DMA in MODE N, so wait 
until SCSI bus inactive before 
changing phase ♦/ 
MR2 = 40h; 
change phase as required; 
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4.0 Device Operation (continued) 

Target Send /* DATA IN PHASE */ 
i 
Program DMA Controller; 
TCR = Olh; /* phase */ 
ICR = 09h; 
HR2 = 4Ah; 

SDS = 0; /* Start DMA Send */ 
while (NOI interrupt) 

idle; 
if (KOI(BSR:END_of_DMA)) 

error; 
else ( /* DMA end */ 
repeat I 

while (CSB:RBQ OR BSR:ACK) 
loop count = 3; 
loop count - - ;l 
/* decrement */ 
until (loop count == 0) ; 
MR2 = 40h; 
Change phase as required ; 



Some explanation of the final part of Target Send is re- 
quired. In this type of DMA operation it is very difficult to 
exactly de termin e the True End of DMA in MODE N. Simply 
detecting REQ and ACK simultaneously inactive Is not 
enough. 

Reference to Figure 4.8.2 mW help to understand the follow- 
ing text. 

As shown in Figure 4.8.2, A CK go ing active caus es the DRQ 
for the next byt e and also REQ to go inactive. ACK going 
inactive allows REQ to go a ctive for the next byte. If the 
INITIATOR is slow rem oving ACK the jxP may sample the 
SCS I bus after the EOP internjpt at point A. Here both REQ 
and ACK will be inactive, but there Is one more byte to 
transfer on SCSI. Due to chip timing delays this condition 
will not last more than 200 ns. A safe way to determine the 
True End of DMA is to sample REQ and ACK and ONLY 
when both are Inactive in three successive samples will the 
\xP be at point B in the figure. 

In MODE E, True End of DMA is correctly decoded and the 
End of DMA interrupt occurs as a r esult o f thi s Tru e condi- 
tion, thus there is no need to sample REQ and ACK. For this 
and other reasons operation in MODE E is strongly recom- 
mended. 



4.8.2 MODE E Non-Block DMA 

Operation for the Non-Block DMA in MODE E is essentially 
the same as MODE N. A primary difference Is that In MODE 
E True End of DMA is decoded internally and this causes an 
Inten-upt. This feature removes the need to check for DMA 
End before moving to the next phase. Additionally, the use 
of the ISR allows easier determination of the end condition. 
For more information on interrupts see Section 6. 
Examples of code are given below. 

Initiator Receive /* DAIA IN PHASE */ 
{ 

Program DMA controller ; 

ICR = Olh; /* phase */ 

ICR = 40h; /* MODE E */ 

MR2 = BEh; 

EMR = 04h; /* Start DMA INIT Rx */ 

while (NOI interrupt) 
idle; 

if (ISR ! = 20h) 
error ; 
else /* DMA end */ 

MR2 = 04h; 
i 

larget Send /* DAIA IN PHASE */ 
( 

Program DMA controller; 

TCR = Olh; /* phase */ 

ICR = 49h; /* MODE E */ 

MR2 = CAh; 

SDS = 0; /* Start DMA Send */ 

while (NOI interrupt) 
idle; 

if (ISR! = 20h) 
error; 

else { /* DMA end */ 

MR2 = 40h; 

Change phase as required ; 



4.9 BLOCK MODE DMA TRANSFERS 

In Block Mode the DMA interface uses the DRQ, 
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FIGURE 4.8.2. Target Send DMA 
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4.0 Device Operation (continued) 

ning of transfers and deasserted once DACK is received. 
Sack should be asse rted continuously for the duration of 
all the transfer. EOP should be asserted during the last 
DMA byte signal when the next DMA byte transfers. The 
EASI asserts the READY signal when the next DMA byte 
should be transferre d. As for non-block mode the End of 
DMA interrupt is just EOP in MODE N, but is a True End of 
DMA in MODE E. 

The block mode is intended for systems where the over- 
head of handing the system busses to and from the jiP and 
DMA controller is too great. The block mode handshake is 
not necessarily faster than non-block (it may be) but the 
overall transfer rate is improved once the bus exchange 
overhead is removed. Of course the jiP is prevented from 
executing for the whole DMA operation. 
If a phase mismatch occurs the READY signal is left in the 
inactive state. The DMA controller must hand back the bus 
to the (iP and the inactive READY signal may need to be 
gated off. For more detail see Section 9. 
When performing DMA as an INITIATOR the EOP signal 
does not deassert ACK on t he SC SI bus in MODE N. Firm- 
ware must determine when REQ is inactive after the last 
SCSI transfer then reset the MR2 DMA bit to deassert ACK. 
In MODE E the EASI correctly handles the deassertion of 
ACK after True End of DMA. 

Programming the EASI in block mode is the same as non- 
block mode except bit 7 in MR2 should also be set. 

4.10 PSEUDO DMA 

The system design can utilize EASI DM A log i c for non data 
transfers. This removes the need to poll REQ/ ACK and pro- 
gram the assertion/deassertlon of the handshake signal. 
The ^P c an emulate a DMA controller by asserting DACK 
and EOP signals. DRQ may be sampled by reading the 
BSR. In most cases the chip decode logic can be adapted 
to this use for little or no cost. See Section 9 for further 
details. 

4.1 1 HALTING A DMA OPERATION 

There are three ways to halt a DMA oper ation apart from a 
chip or SCSI reset. These methods are: EOP, phase mis- 
match and resetting the DMA MODE bit in MR2. 

4.1 1.1 End of Process 

EOP is ass erted for a minimum period during the last DMA 
cycle. The EOP signal generates the End of DMA interrupt 
in MODE N, and e nables the True End of DMA to occur later 
in MODE E. EOP does not cause the MR2 DMA mode bit to 
be reset. 

4.11.2 DMA Phase Mismatch 

If a REQ goes active while there is a phase mismatch the 
DMA will be halted and an intermpt generated. The EASI 
will stop driving the SCSI bus when the mismatch occurs. A 
phase mismatch is when the TCR phase bits do not match 
the SCSI bus values. 

4.1 1.3 DMA Mode Bit 

If EOP is not used, the best method is to reset the MR2 
DMA Mode bit. This bit may be reset at any time, and should 
be reset after an End of DMA interrupt or a phase mismatch. 
Resetting the bit disables all DMA logic and thus should 
only be reset at the True End of DMA condition. Additional- 
ly, all DMA logic is reset, so this bit must be reset then set 
again to carry out the next DMA phase. 



5.0 Interrupts 

5.1 OVERVIEW 

The EASI is Intended to be used in an internjpt driven envi- 
ronment. MODE E has greatly enhanced the use of inter- 
rupts to relieve firmware overhead. This section describes 
the conditions for and use of each interrupt. Each descrip- 
tion explains MODE N then MODE E operation. 
Before individually describing each interrupt, an explanation 
of the use of interrupts is required. 

5.2 USING INTERRUPTS 

MODE N: In this mode interrupts are controlled by bits in 
MR2 if control is provided. Not all interrupts can be disabled 
under software control. When an interrupt occurs, both the 
BSR and CSD register must be read and analyzed to deter- 
mine the source of interrupt. Since status is NOT provided 
for each interrupt, great care should be exercised when de- 
termining the interrupt source. 

MODE E: In this mode every interrupt can be individually 
masked and enabled or disabled. In addition, when an inter- 
rupt occurs a single register (ISR) can be read to determine 
the source(s) of interrupt. An associated register (IMR) al- 
lows a mask bit to be set for each interrupt. Finally, the 
design of the logic prevents loss of interrupts occurring after 
the INT signal goes Active and before the Reset Parity/In- 
terrupt function. In MODE N loss of interrupts can occur. 

5.3 SCSI PARITY ERROR 

MODE N: If SCSI parity checking is enabled via MR2 bit 5, 
an interrupt can occur as a result of a read from CSD, a 
selection/(re)selectlon, or a DMA receive operation. The 
parity error bit (bit 5) In the BSR will be set if checking is 
enabled. An Interrupt will occur If Enable Parity Interrupt (bit 
4) of MR2 is set. The interrupt is reset by reading HA 7. 
Following an interrupt the BSR and CSB should contain the 
values shown below. 



Bit? 



BitO 
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X 


1 


1 


X 


X 


X 


X 



EDMA DRQ SPER INT PHSM BSY ATN ACK 
BSR 



Bit 7 














BItO 





1 


X 


X 


X 


X 





X 



RST BSY REQ MSG C/D T7c3 SEL DBP 
CSB 

5.4 JU.P PARITY ERROR 

MODE N: |xP parity is not available under this mode. 
MODE E: if bit 6 of the EMR is 1, fiP parity will be checked 
on a write to the EASI via the ]aP or DMA controller. The 
parity polarity is determined by bit 5 of the EMR. If bit 6 of 
the IMR is zero, a )i,P parity error will set bit 6 of the ISR and 
cause an interrupt. The interrupt may be reset by writing 01 
to bits 2 and 1 of the EMR followed by any other pattern. 

5.5 END OF DMA 

MODE N: If EOP Is asserted during a DMA transfer, bit 7 of 
the BSR will be set and an interru pt ge n erated If bit 3 of 
MR2 Is 1. EO P is recognized when EOP, DACK and either 
lOR or low are all simultaneously active for a minimum 
period. The interrupt may be reset by reading HA 7. Follow- 
ing an interrupt the BSR and CSB should contain the values 
shown below. 
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5.0 Interrupts (continued) 

Bit? 



BItO 
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X 



RST BSY REQ MSS C/D I/O SEL DBP 
CSB 

5.6 DMA PHASE iUiSMATCH 

MODE N: When the SCSI REQ goes active during a DMA 
operation the cont ents of the TCR are compared with the 
SCSI phase lines C7D, MSG and ]70. If the two do not 
match an Intemjpt Is generated. This Interrupt will occur as 
long as the MR2 DMA bit Is set (bit 1), I.e., it cannot be 
masked In MODE N. The mismatch removes the EASI from 
driving the SCSI data bus. The Interrupt may reset by read- 
ing HA 7. Following an inten-upt the BSR and CSB should 
contain the values shown below. 
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RST BSY REQ 



MSS CTD 
CSB 



I/O SEL DBP 



MODE E: Bit 4 of the ISR will be set by a DMA phase mis- 
match — the same conditions as MODE N. The Interrupt and 
setting If ISR bit 4 may be masked by setting bit 4 of the 
IMR. The Interrupt may be reset by writing 01 to bits 2 and 1 
of the EMR followed by any other pattern. 

5.? ANY PHASE MISMATCH 

MODE N: This feature Is not available under this mode. 
MODE E: This condition Is similar to DMA Phase Mismatch 
except that It applies to all operations — not just DMA. If the 
TCR contents do not match the SCSI phase lines when 
REQ goes active an Interrupt is generated and bit 3 set In 
the ISR. The ISR bit and the Internjpt may be masked by 
setting bit 3 In the IMR. The interrupt may be reset by writing 
01 to bits 2 and 1 of the EMR followed by any other pattern. 

5.8 BUSY LOSS 

MODE N: If bit 2 In MR2 Is set the SCSI BSY signal Is 
monitored and an Inten-upt Is generated if BSY is continu- 
ously Inactive for at least a BUS SETTLE DELAY (400 ns). 
This Interrupt may be reset by reading HA 7. Following an 
Interrupt the BSR and CSB should contain the values shown 
below, where usually CSB = 00. 
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EDMA DRQ SPER INT PHSM BSY ATN ACK 
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RST BSY REQ MSG C/D I/O SEL DBP 
CSB 
MODE E: Bit 2 in MR2 performs the same function as In 
MODE N. When an Interrupt Is generated bit 2 In the ISR will 
be set. The ISR bit and the Interrupt may be masked by 
setting bit 2 In the IMR. The Interrupt may be reset by writing 
01 to bits 2 and 1 of the EMR followed by any other pattern. 

5.9 (RE)SELECTION 

MODE N: An Interrupt will be generated when: SEL Is active, 

BSY is Inactive, and the device ID Is true. The device ID Is 

determined by the value In the SER. If ANY non-zero bit In 

the SER has Its corresponding SCS I data bit active during 

selection, the device ID is true. If I/O Is active this Is a rese- 

lection. The interrupt is disabled by writing all zeroes to the 

SER, and reset by reading HA 7, 

If SCSI parity checking Is enabled It will be checked and 

should be valid. Following an Interrupt the BSR and CSB 

should contain the values shown below. 
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EDMA DRQ SPER INT PHSM BSY ATN ACK 
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RST BSY REQ MSG C/D I/O SEL DBP 
CSB 
MODE E: The functioning of the (re)selection logic Is the 
same as for MODE N. Additionally, bit 1 In the ISR will be 
set upon a (re)selectlon Interrupt. The interrupt and setting 
of bit 1 In the ISR may be masked by setting bit 1 In the IMR. 
The interrupt may be reset by writing all zeroes to the SER 
then writing 01 to bits 2 and 1 of the EMR followed by any 
other pattern. 

5.10 ARBiTRATION COMPLETE 
MODE N: No interrupt is generated In MODE N. 
MODE E: When bit of the EMR Is set to 1 the EASI moni- 
tors BSY and SEL to determine a BUS FREE Phase. The 
EASI then carries out all steps required for bus arbitration. 
When either arbitration is lost or the arbitration process has 
completed, bit In the ISR is set and an Interrupt generated. 
The Internjpt and bit In the ISR can be masked by setting 
bit In the IMR. Note that arbitration is not affected by the 
IMR, just the Interrupt. 



6.0 Reset Conditions 

6.1 GENERAL 



There are three ways to reset the EASI; |nP chip RESET, 
SCSI bus reset applied externally, SCSI bus reset Issued by 
the EASI. 

6.2 CHIP RESET 



When the RESET signal Is asserted for the required dura- 
tion the EASI clears ALL Internal registers and therefore 
resets all logic. This action does not create an interrupt or 
generate a SCSI reset. Since all registers contain zeroes, 
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6.0 Reset Conditions (continued) 

the EASI is In MODE N under any of the three reset condi- 
tions. 

6.3 EXTERNAL SCSI RESET 

When an SCSi RST is applied externally the EASI resets all 
registers and logic and issues an interrupt. The only register 
bits not affected are the Assert RST bit (bit 7) in the ICR and 
the TARGET Mode bit (bit 6) in MR2. Note that the ISR will 
contain all zeroes. 

6.4 SCSI RESET ISSUED 

When the fiP sets the Assert RST bit in the ICR, the RST 
signal goes active. Since the EASI monitors RST also, the 
same reset actions as in 6.2 apply. The SCSI RST signal will 
remain active as long a s bit 7 i n the ICR is set— i.e., until 
programmed or a chip RESET occurs. 

7.0 Loopbacl( Testing 

7.1 GENERAL 

The DP8490 EASI features loopback testing, enabled by bit 
3 of the EMR. When the LOOP bit is set in the EMR all SCSI 
drivers are disabled at the pads and the signals looped back 
Internally. Additionally, ttoth TARGET and INITIATOR sig- 
nals may be simultaneously asserted — ^this is not possible in 
normal operation. All this enables testing of EASI operation 
without affecting the SCSI bus. 

7.2 SCSI SIGNAL DRIVING/MONITORING 

Since each SCSI signal is looped back, testing is accom- 
plished by asserting a signal via the ICR or TCR, then read- 
ing back via CSB and BSR to check its state. The code 
below provides examples. The first example tests SCSI con- 
trol signals and the second the SCSI data bus. Note that 
loopback mode must be enabled prior to asserting any sig- 
nals if they are not to drive the SCSI bus. 
SCSI-Slgnal_test 



ICR = 40h; /* MODE E */ 

EMR = 08h; /* LOOPbaok */ 

ICR = 5Eh; /* drive IHII controls */ 

ICR = OFh; /* drive lARG controls */ 



if((CSB=7Eh) AKD (BSR=OFh)) 

ok; 
else error; 



SCSI_data_test 
I 

ICR = 40h; 

EMR = 08h; 

ICR = 41h; 

MR2 = 30h; 

ODR = OAAh; 

if(CSD=OAAh) 

else error; 

ODR = 55h; 

if(CSD=55h) 

else error; 

if (interrupt ) error ; 

else ok; 



/* MODE £ */ 

/* liOOPbaok •/ 

/* assert data bus «/ 

/* parity check & interrupt */ 

ok; 



ok; 



7.3 (RE)SELECTION AND ARBITRATION 

Both these features may be tested in loopback. Note that 
when checking BSY via the CSB register the "debounced" 
version of BSY is presented and will be active for 400 ns- 
800 ns after BSY goes inactive. Logic within the EASI con- 
tinuously monitors BSY when it becomes inactive to detect 
a valid Bus Free Phase. One of the outputs of this logic is a 
clean version of BSY which is accessed through the CSB. 

7.4 DATA TRANSFERS 

Both programmed-l/O and DMA transfers may be per- 
formed. When doing DMA transfers the MR2 TARGET 
MODE bit (6) must be programmed according to the type of 
DMA — i.e., set to 1 for TARGET Send or Receive, reset to 
for INITIATOR Send or Receive. Additionally, the actions of 
the other SCSI device must be programmed. For example, 
when testing INITIATOR operations the BSY signal must be 
set via ICR to simulate a TARGET connected, and the REQ 
signal must be programmed active and inactive to perform 
the handshake. The code below shows a single byte trans- 
fer as INITIATOR Send. 
DHA_test 



program DMA controller; 
ICR = 40h; /* MODE E •/ 

EMR = 08h; /* LOOPbaok */ 

ICR = 49h; /* BSY & data bus on */ 
MR2 = OAh; /* DMA. 8: EOF interrupt */ 

ICR = 08h; /* assert REQ */ 

SDS = ; /* Start DMA Send */ 

/* DMA cycle with EOF is done here */ 
ICR = ; /* deassert REQ */ 

if(IDR==data byte) ok; 
else error; 
if(BSR==90h) ok; 
else error; 

/* also should be an EOP interrupt */ 
i 

8.0 Extra Features/Compatibility 

8.1 OPERATING MODES 

This section is intended to clearly indentify the differences 
between the DP8490 and DP5380. The description covers 
registers, signals, timing, "bugs" and enhancements. For a 
more detailed description of register programming and bit 
functions refer to Sections 3-7. 

Before discussing differences a review of DP8490 operation 
is required. The EASI can be operated in two modes — Nor- 
mal Mode (MODE N) and Enhanced Mode (MODE E). The 
EASI is in one or the other mode at any time. MODE E is 
selected when bit 6 in the INITIATOR COMMAND REGIS- 
TER (ICR) is set to 1 . A SCSI or external chip reset clears all 
registers (except MODE REGISTER 2 bit 6) so MODE N is 
selected as the default MODE N may also be selected at 
any time by clearing bit 6 of the ICR to zero. If MODE E 



/* no parity errors */ 
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8.0 Extra Features/Compatibility (continued) 

functions have been invoked, selecting MODE N does not in 
general affect their operation. This means MODE E is used 
to enable selection of enhanced features which can be used 
in either mode. Normally an application will choose to re- 
main in MODE E always since all functions are accessible In 
this mode. MODE N is only required for downward compati- 
bility with a standard 5380 device. The DP5380 operates 
ONLY in MODE N. 

The MODE selection via bit 6 of the ICR enables existing 
5380 firmware to mn unaltered with the EASI. On the 5380 
this is a TEST MODE bit which disables ALL output driv- 
ers— NOTHING ELSE! No logic Is "tested" and no changes 
are made to internal logic. Since the jiP data bus drivers are 
also disabled the internal state of the 5380 is inaccessible. 
This means the TEST MODE bit has very limited application 
for the end user. By comparison the LOOPBACK bit in the 
EASI enables thorough testing of device operation. 
In summary, cuffent operating firmware should not be using 
bit 6 of the ICR so the DP8490 uses this bit to enable en- 
hanced operation. As long as this bit is not set in the EASI 
the DP8490 appears the same as the NCR, AMD or 
DP5380. Programming, device operation, and timing se- 
quences are all the same as a 5380. 

8.2 INTERNAL REGISTERS 

Figure 8. 1 shows the register map of the EASI. Note that in 
MODE N hex address 7 (HA 7) causes a Parity/lntermpt 
Reset when read and a Start DMA Initiator Receive when 
written. In MODE E the read/write EXTRA MODE REGIS- 
TER (EMR) is mapped into HA 7. Since the two original 
functions at HA 7 would conflict, their functions are repro- 
duced by writing to bits 1 and 2 of the EMR. This removes 
any need to switch between modes. The INTERRUPT 
MASK REGISTER (IMR) and the INTERRUPT STATUS 
REGISTER (ISR) are accessed indirectly via the EMR. Set- 
ting both bits 1 and 2 of the EMR to 1 enables the next read 
of address 7 to access the ISR or the next write to access 
the IMR. Once the access Is made subsequent uses of ad- 
dress 7 use the EMR. 



Hex 


Read 


Wrife 


Addr 


Register 


Register 


00 


Current SCSI Data 


Output Data Register 


01 


Initiator Command 


Initiator Command 


02 


Mode Register 2 


Mode Register 2 


03 


Target Command 


Target Command 


04 


Cunent SCSI Bus Status 


Select Enable Register 


05 


Bus and Status 


Start DMA Send 


06 


Input Data Register 


Start DMA Targ Rx 


07 


Reset Parity/Interrupt 


Start DM>!ilnitRx 




(MODE N) 


(MODE N) 


07 


Extra Mode Register 


Extra Mode Register 




(MODE E) 


(MODE E) 


07 


Interrupt Status Reg 


Intermpt Mask Reg 




(MODE E and bits 1 


(MODE E and bits 1 




and 2 of EMR = 1) 


and2ofEMR = 1) 



ables the extra functions. Setting an EMR bit to 1 enables 
the corresponding function while programming a disables 
it. Note on power-up or reset the EMR is zeroed so all extra 
functions are disabled. The INTERRUPT MASK REGISTER 
(IMR) provides the ability to individually mask out interrupts. 
The INTERRUPT STATUS REGISTER (ISR) shows the 
status of the Internjpt system at any time. When an interrupt 
occurs the ISR will contain 1's for inten-upts that are active, 
enabled and not masked. Figure 8.2 shows the format of the 
three registers. 

8.4 EMR FEATURES 

8.4.1 Arbitration 

In MODE N, arbitration is enabled via bit of MR2. However 
this requires polling the device for potentially many millisec- 
onds. The juP polls the ICR for the ARBITRATION IN 
PROGRESS bit (6) which is set once the ASI/EASi detects 
a bus free phase and enters arbitration. The juP must then 
wait for the 2.2 jts ARBITRATION DELAY before checking 
IDs on the bus. No intenupt is given for any of these events. 
In MODE E, EASI arbitration is enabled by bit of either 
MR2 or EMR. The EMR bit enables extended arbitration. 
The EASI will wait for bus free, arbitrate, wait the 2.2 jts 
ARBITRATION DELAY and the INTERRUPT the ^P if not 
masked in the IMR. An interrupt occurs if arbitration is com- 
plete or has been lost. This feature removes the need to poll 
the EASk 

7 ENHANCED MODE REdSTEK 



FIGURE 8.1. EASI Register Map 
8.3 ENHANCEMENT MODE REGISTERS 

MODE E provides three new registers to provide control for 
the extra features of the EASI. The EXTRA MODE REGIS- 
TER (EMR) is a read/write register which enables or dis- 



































1 

Extended 






1 


Arijilratkin 












00 = NOP 












01 = Reset Parity /Ini 












10 = Start DMA InHRx 












11 = Rd/Wr ISR/IMR 










Loopback Mode 








SCSI Parity (ODD/EVEN) 






>.P Parity (ODD/EVEN) 




/»P ParRy Enable 


Interrupt on any Phase Mismatch 


TL/F/9387-9 


7 


1 


NTERRUP 


T MASK/ 


STATUS 


REGISTEI 


i 













J 




J 




J 




J 




J 


■- 


J 


1 

Arbltra 


tlon 
















Complete 














(Re)Selectian 












Busy Loss 










Any Phase Mlsn»tch 








DMA Phase Mismatch 






DMA End 




^P Parity Error 


SC 


SIP 


irlty 


Err 


or 

























FIGURE 8.2. MODE E Registers 
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8.0 Extra Features/Compatibility (continued) 

8.4.2 Loopbaok Mode 

When bit 3 is set in the EMR the EASI disables all SCSI 
drivers and loops back the sign a ls internall y . SCS I Dat a Out 
is link ed to SCSI Data In. BgY, §EL, STN, RST, 170, C7D, 
MSG, REQ and ACK outputs are fed back to their own in- 
puts. This enables testing of EAS( operations, including 
DMA. 

8.4.3 SCSI Parity 

SCSI parity may be enabled and also cause an interrupt (or 
be masked). Bit 4 of the EMR allows the polarity of SCSI 
parity to be set to either ODD or EVEN, with a default of 
ODD. This feature allows checking of SCSI devices and ca- 
ble. It also allows an INITIATOR to automatically detect 
whether a device supports parity. (Send a parity error and 
check it is reported). 

8.4.4 f;iP Parity 

The EASI includes parity for the jaP data bus. This enables 
controllers to validate data while It passes through their data 
buffers. In common with SCSI parity the jxP parity may be: 
enabled/disabled, interrupt or be masked, be EVEN or ODD 
polarity. 

8.4.5 Phase Mismatch 

In MODE N the EASI will only give a Phase Mismatch inter- 
rupt during DMA (normally data) transfers. In MODE E an 
interrupt can also be programmed for a ph ase m ismatch 
during any phase. The mismatch is detected if REQ is active 
and the phase lines do not match the phase expected as 
specified in the TCR bits to 2. This feature allows com- 
pletely interrapt-driven operation of the EASI. 

8.5 INTERRUPTS 

The EASI has an improved interrupt structure to ease pro- 
gramming. In MODE N the structure is the same as a stan- 
dard 5380. In this mode Interrupts can occur which may only 
be determined by the lack of other interrupts (e.g.. Selection 
and Phase Mismatch). Interrupts can also be missed if they 
occur while servicing others. To determine the cause of an 
interrupt requires reading the BSR and CSB registers then 
interpreting the results, knowing what the 5380 was current- 
ly doing. 

In MODE E interrupts can be individually masked via the 
IMR and active ones determined by reading the ISR. Any 
unmasked interrupts sets an ISR bit to 1 . After the interrupt 
service routine the /u.P should perform a Reset Parity/Inter- 
rupt function via the EMR— this will ONLY RESET interrupts 
which had a 1 in the ISR when it was last read. This feature 
means interrupts will not be lost. . 

8.6 TIMING 

The NCR5380 timing has some aspects which have been 
improved for MODE E of the EASI. In MODE N timing de- 
tails are the same as the 5380. Of course the DP5380 ASI 
remains the same as the NCR5380. The timing improve- 
ments are listed below. 

1. True End of DMA: In MODE N the end of DMA is when 
the last byte is transferred by the DMA controller, not 
when the final SCSI transfer is done. In MODE E bit 7 of 
the TCR shows a true end of DMA status — i.e., the last 
byte transfen-ed by the later of the two events. This bit is 
compatible with the NCR CMOS 53C80. 



2. SCSI Handshakeafter EOP: in MODE N, INITIATOR re- 

cei ve wh en a REQ is received after EOP has been given 

an ACK will be generated although no valid data exists 

since no D RQ w as issued. The EASI will NOT generate 

this invalid ACK while In MODE E. 

(xP and DMA accesses have relaxed timing on both the 

EASI and ASI. Data setup/hold and read access times are 

reduced. Faster handshaking on the SCSI bus, along with 

faster response to the DMA signals means that higher 

transfer rates are possible with both devices — ^typically over 

3 MBytes/s. 

9.0 Application Guide 

This section is Intended to show the interface between the 
fiP, EASI and DMA controller (DMAC). Figure 9. 1 shows a 
general Interface when the EASI and DMAC are l/O- 
mapped devices. This configuration will Implement a 2 to 
2.5 MBytes/s SCSI port using 2 cycle compressed timing 
from the 5 MHz DMAC. 

Using a faster DMAC and ntiemory may allow the EASI to 
operate at a higher rate — but of course any system will be 
limited by the available DMA rate from the SCSI device cur- 
rently connected to. The interface shown has several fea- 
tures that are examined more closely in the following text. 
All the interface signal requirements are satisfied by a PAL 
device. The memory interface is not shown, only the rele- 
vant DMAC and fiP lines are included. 
The EASI data and address lines connect directly to the 
nP/DMAC busses. The DRQ output from the EASI goes 
direct to the DMAC. The EOP output from the DMAC goes 
to the EASI input, via the PAL, but can also be asserted via 
the PAL since the DMAC output is open-drain. 
The PAL is programmed so that the jliP can access the 
EASI in three ways. The thr ee ac cess types are: Register 
B/W, DMA R/W, DMA with EOP. Examination of the PAL 
equations below shows how the fiP may perform any of the 
three basic access types simply by accessing the EASI at 
different I/O address slots. This enables the ju,P to simulate 
a DMAC (pseudo-DMA). DMA mode may then be used for 
all information transfer phases. 

In DMA mode the EASI generates all SC SI handshak es. At 
ail other times the juP is responsible for REQ/ACK hand- 
shakes. Using pseudo-DMA may reduce jiP overhead. 
When doing DMA transfers via BLOCK MODE and an error 
occurs, the EASI may not deassert the READY signal. For 
some DMA controllers this may lock the bus, so the PAL 
asserts READY and EOP to the DMA If an Interrupt occurs 
while READY is false. This completes.the current DMA cy- 
cle and prevents further DMA for the rest of the block thus 
allowing the bus to be handed back to the jxP for servicing. 
The PAL generates lOR and lOW strobes while the jxP is 
bus master, but the DMAC provides the strobes While it is 
bus master so the PAL outputs are TRI-STATE. 
The PAL details are shown in Figure 9.2 with the signal 
definitions and equations following. 
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9.0 Application Guide (continued) 



liP Interface 









dataT 1 




^ 






5 MHz 
DMAC 


OREQ 
DEOP 

MEMR 

MEMW 

READY 

AEN 

DOACK 

iOR 

low 


^^^ 


^ 


DRQ 

INT 

READY 
EDACK 
CS 

EEOP 

EASIWR 

RD 


EASI 


T||||| 


Address ^ 


I 








"^ 
























PAL 

NSC 

PAL 
2DLI0 


iORQ^ 






RD 




t 


WR 








_t 
























^ 









































D 
"O 
{OS 
■Ck 
<D 

o 



FIGURE 9.1. |itP/EASI/DMA Interface 



TL/F/9387-11 



ff 



DMAC 



EASI 



A7- 
A6- 
A5- 
A4- 
iORQ- 
RD- 
WR- 

AEN - 
DDACK- 

EREADY- 
INT- 



NSCPAL 
2DLtO 



-► EASIWR 
-► CSEAS I 

-►EDACK 
-►EEOP 



EASI 



► DEOP 
► CSDMA 

► DREADY 

►IOR DMAC 

► BW 



FIGURE 9.2. Interface PAL 
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9.0 Application Guide (continued) 

/CSEASI = /I0RQ*/A7*/A6*/A5*/A4*/AEN 
/EDACK = /I0RI1*/A7*/A6*/A5* A4*/RD 
/I0RQ*/A7*/A6*/A5* A4*/WR 
+/I0RQ*/A7*/A6* A5*/A4*/RD 
+/I0RQ*/A7*/A6* A5* A4*/WR 
+/DDACK 
/EEOP = /I0RQ*/A7*/A6« A5*/A4*/RD*/AEN 
+/I0RQ*/A7«/A6* A5*/A4*/WR*/AEN 
+/DEOP*EREADY 

IF(/DDACK*/EREADY*INI)/DEOP = /DDACK*/EREADY 

transfer. 

/CSDMA = /I0RQ*/A7*/A6»A5«A4 

/DREADY = /EREADY*/INT 

+/EREADY*/DDACK 
IF(/AEN) /lOR = /IORQ*/RD 
IF(/AEN) /low = /IORQ*/WR 
/EASIWR = /lORQ* WR«/AEN+/IOW*EREADY*AEN 



EASI reg R/W chip select 
fiT pseudo-DMA cycle 

(iP pseudo-DMA with EOP 

DMAC DMA cycle 

(iP pseudo-DMA with EOP 



Prevents EASI from seeing 
EOP until READY goes high. 
*INI ; on error this will terminate the DMA 

DMAO register R/W 

EASI not READY and not INT 

EASI not READY and DMA cycle active 

li? I/O Read cycle 

liP I/O Write cycle 

Prevents SCSI data being 

changed before EASI is 

READY for next byte. 



FIGURE 9.3. PAL Equations 



The jLiP and DMA signals are 


defined below 


A7-A4 


Address bus 


iORQ 


Memory I/O cycle select 


RD 


Read Strobe 


WR 


Write Strobe 


AEN 


High DMA address enable asserted by DMAC 


DDACK 


DMAC DMA Acknowledge 


CSDMA 


DMA Chip Select 


DREADY 


Ready signal to DMAC— inserts wait-states when low 


lOR, low 


I/O data strobes to/from DMAC 


EASIWR 


EASI write strobe. 
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10.0 Absolute Maximum Ratings'' 

If Military/Aerospace specified devices are required, 
please contact tlie National Semiconductor Sales 
Office/Distributors for avaiiabiiity and specifications. 

Supply Voltage (Vqc) -0.5V to + 7.0V 

DC Input Voltage (V|n) -0.5V to Vcc + 0.5V 



DC Output Voltage (Vqut) 
Storage Temperature Range Ustg) 
Power Dissipation (Pq) 
Lead Temperature (TJ 

(Spidering, 10 seconds) 
Electro-Static Discharge Rating 



-0.5VtoVcc + 0.5V 

-65°Gto+150°C 

500 mW 

260°C 
2kV 



'Absolute maximum ratings are those values beyond wtiicli damage to the device may occur. 

11.0 DC Electrical Characteristics 

Ta = OfC to +70°C, Vcc = 5.0V ±5% unless othenwise specified 



Symbol 



V|H 



V|L 



VOHI 
V0H2 



V0L1 
Voi^ 
V0L3 



■in 



loz 



te 



Parameter 



Minimum High Level 
Input Voltage 



Maximum Low Level 
Input Voltage 



Minimum High Level 
Output Voltage 



Maximum Low Level 
Output Voltage 



Maximum Input Current 



Maximum TRI-STATE Output 
Leakage Current 



Supply Current 



Conditions 



IIoutI = 20 JJ.A 
I burl = 4.0 mA 



SCSI Bus Pins: IIqlI = 48 mA 
Other Pins: |IolI = 20 nA 
2 IIqlI = 8-0 mA 



V|N = Vcc or GND 



VoUT = Vcc or GND 



V|N = Vcc or GND 
SCSI Inputs = 3V 



Typ 



2.5 



Capacitance ta = 25°c,f = i mhz 



Symbol 


Parameter (Note 3) 


Typ 


Units 


CjN 


Input Capacitance 


5 


PF 


COUT 


Output Capacitance 


7 


PF 



AC Test Conditions 



Input Pulse Levels 


GND to 3.0V 


Input Rise and Fall Time 


6 ns 


Input/Output Reference Levels 


1.3V 


TRI-STATE Reference Levels 
(Note 2) 


active low + 0.5V 


active high - 0.5V 



Input ( 



Note 1: Cl = 50 pF including jig and scope capacitance. 

Note 2: si = Open for push-pull outputs. 

Si = Vcc for active low to TRI-STATE 
31 = GND for active high to TRI-STATE. 

Note 3: This parameter is not 1 00% tested. 



Limit 



2.0 



0.8 



Vcc - 0.1 
2.4 



0.5 
0.1 
0.4 



±1 



±10 



Units 



V 
V 
V 



fiA 



jiA 



mA 
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12.0 AC Electrical Characteristrcs 

All parameters are preliminary and subject to change without notice 


Symbol 


Parameter 


DP8490 


Units 


Min 


Typ 


Max 


bfas 


BSY false to arbitrate start 


1200 




2200 


ns 


bfbc 


BSY false to bus clear 






800 


ns 


stbc 


SEL true to bus clear 






500 


ns 


rst 


RESET pulse width 


100 






ns 



12.1 ARBITRATION 



SEL 



BSY 



J 



-bfas- 



BSY 



12.2 |iiP RESET 



RESET 



^L 



\ 



-stbc- 



\. 



r 



-rst- 



■bfbc- 



£. 



j^ 



TL/F/93B7-14 



TL/F/9387-15 
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12.0 Electrical Characteristics 

12.3 jiP WRITE 



A0..2 



CS 



^^ 



WR 



V 



D0..7 



-dsw- 



-ahvK- 



3C 



;^ 



f 



-dhw- 



12.4 \)9 READ 



A0..2 



CS 



ahr - 



3C 



'K. 



RD 



A. 



D0..7 



• rdv- 



- csh- 



J^ 



J^ 



■ dhr- 



3C 



TL/F/9387-17 



Symbol 


Parameter 


DP8490 


Units 


Min 


Typ 


Max 




ahr 


Address Hold from and of Read Enable (Note 1 ) 


5 






ns 


ahw 


Address Hold from End of Write Enable (Note 2) 


5 






ns 


as 


Address Setup to Read or Write Enable (Notes 1 ,2) 


5 






ns 


csh 


CS Hold from End of RD or WR 









ns 


dhr 


Data Hold from End of Read Enable (Notes 1 ,3) 


20 




60 


ns 


dhw 


fiP Data Hold Time from End of WR 


10 






ns 


dsw 


Data Setup to End of Write Enable (no \)P Parity) 
(Note 2) (with ftP Parity) 


35 
35 






ns 
ns 


rdv 


Data Valid from Read Enable (Note 1 ) 






50 


ns 


WW 


Write Enable Width (Note 2) 


40 






ns 



o 
■o 

OS 

o 



a 



Note 1: Read enable (/iP) is CS and RD active. 

Note 2: Wnte enable (ftP) is CS and WR active. 

Note 3: This indudes the RC delay inherent in the test's method. These signals typically turn off after 25 ns, enabling other devices to drive these lines with no 

contention. 
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12.0 AC Electrical Characteristics (continued) 

12.5 DMA WRITE (NON-BLOCK MODE) TARGET SEND 



DRQ 



J 



DACK 



WR 



D0..7 



EOP 



REQ 



atdt— 



ACK 



"^^ 



"\ 



- dtdf - 



■^^ 



J 



wwn - 



- dswd - 



-dkhw- 



J^ 



- dhwr- 



- eop ■- 



\. 



j^ 



atrf-H 



- dfdt - 



j'' 



-dfrt- 



7^ 



\ 



-afrt- 



j"- 



DBO.J.P 



Byle n 



XIZ3( 



-dsrt ► 



Byte n + 1 



TL/F/9387-1B 



Symbol 


Parameter 


DP8490 




Min 


Typ 


Max 




afrt 


ACK False to REQ True (DACK or WR False) 






75 


ns 


atdt 


ACK True to DRQ True 






55 


ns 


atrf 


ACK True to REQ False 






100 


ns 


dfdt 


DACK False to DRQ True 


30 


90 




ns 


dfrt 


DACK False to REQ True (ACK False) 






75 


ns 


dhwr 


DMA Data Hold Time from End of WR 


10 






ns 


dkhw 


DACK Hold from End of WR 









ns 


dsrt 


SCSI Data Setup to REQ True 


25 






ns 


dswd 


Data Setup to End of DMA Write Enable (no nP Parity) 
(Note1) (with fiP Parity) 


35 
35 






ns 
ns 


dtdf 


DACK True to DRQ False 






45 


ns 


eop 


Width of EOP Pulse (Note 2) 


25 






ns 


wwn 


DMA Non-block Mode Write Enable Width (Note 2) 


40 






ns 



Note 1: Write enable 
Note 2: EDP, DACK, 



(DMA) is DACK and WR active. 

RD/WR must all be true for recognition of EOF. 
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12.0 AC Electrical Characteristics (continued) 

12.6 DMA WRITE (NON-BLOCK MODE) INITIATOR SEND 



DM 



f 



DACK 



WR 



\ 



D0..7 



EOP 



-rfdl-» 



^L 



V 



f 



-rtat-H 



ACK 



\ 



-dtdf- 



■^L 



^ 



j"" 



-dswd- 



-dkhw- 



J^ 



- dhwr- 



f 



-dfdt- 



-dfaf- 



DB0..7,P 



Byte n 



3C 



X 



Byte n + 1 



TL/F/9387-19 



o 

I 



Symbol 


Parameter 


DP8490 


Units 


Min 


Typ 


Max 


dfaf 


DACK False to ACK False 






90 


ns 


dfdt 


DACK False to DRQ True 


30 


90 




ns 


dhi 


SCSI Data Hold from Write Enable-lnitiator 


15 






ns 


dhwr 


DMA Data Hold Time from End of WR 


10 






ns 


dkhw 


DACK Hold from End of WR 









ns 


dswd 


Data Setup to End of DMA Write Enable (no \>P Parity) 
(Note1) (with fiP Parity) 


35 
35 






ns 
ns 


dtdf 


DACK True to DRQ False 






45 


ns 


eop 


Width of EOP Pulse (Note 2) 


25 






ns 


rfdt 


REQ False to DRQ True 






60 


ns 


rtat 


REQ True to ACK True 






80 


ns 


wwn 


DMA Write Enable Width (Note 1) 


40 






ns 



Not* 1: Write enable (DMA) Is DACK and WR active. 

Note 2: EOP, DACK, RD/WR must all be true for recognition of EOP. 
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12.0 AC Electrical Characteristics (continued) 

12.7 DMA READ (NON-BLOCK MODE) TARGET RECEIVE 



DRQ 



y 



DACK 



^^ 



RD 



D0..7 



v 



-dtdf- 



\ 



-ddv- 



-dkhr- 



-dfdt- 



J^ 



7^ 



-dhr- 



Byte n 



EOP 



REQ 



J 



ACK 



atrf-* 



[)B0..7,P 3 ^ 



dsra 



-atdt- 



-«ap- 



V 



J'' 



-dfrt- 



-afrt- 



7^ 



-dhra- 



Byte n 



DC 



TL/F/93e7-20 



Symbol 


Parameter 


DP8490 


Units 


Min 


Typ 


Max 


afrt 


ACK False to REQ True (DACK or WR False) 






75 


ns 


atdt 


ACK True to DRQ True 






55 


ns 


atrf 


ACK True to REQ False 






100 


ns 


ddv 


DMA Data Valid from Read Enable (Note 1 ) 






40 


ns 


dfdt 


DACK False to DRQ True 


30 


90 




ns 


dfrt 


DACK False to REQ True (ACK False) 






75 


ns 


dhr 


Data Hold from End of Read Enable (Notes 1, 2) 


20 




60 


ns 


dhra 


SCSI Data Hold from ACK True 


15 






ns 


dkhr 


•DACK Hold from End of RD 









ns 


dsra 


SCSI Data Setup Time to ACK True 


10 






ns 


dtdf 


DACKToie to DRQ False 






45 


ns 


eop 


Width of EOP Pulse (Note 3) 


25 






ns 



Note 1: Read enable (DMA) is DACK and RD active. 

Note 2: Tliis includes the RC delay Intierent in the test's method. These signals typically turn off after 25 ns enabling other devices to drive these lines with no 

contention. 

Note 3: EOP, DACK, RD/WR must all be true for recognition of EOP. 
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12.0 AC Electrical Characteristics (continued) 

12.8 DMA READ (NON-BLOCK MODE) INITIATOR RECEIVE 



DRQ 



y 



DACK 



^L 



RD 



■\ 



-dtdf- 



\ 



/ 



-ddv- 



D0..7 



-dkhr- 



-dfdt- 



j'' 



-dhr- 



Byle n 



3C 



EOP 



REQ 



^. 



DB0..7,P 



Z3i 



dsra 



-rtdt- 



■^^ 



j' 



-rtat- 



-rfaf- 



j'' 



I— dfaf- 



■^^ 



j'' 



-dhra- 



Byte n 
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Symbol 


Parameter 


DP8490 


Units 




MIn 


Typ 


Max 


ddv 


DMA Data Valid from Read Enable (Note 1) 






40 


ns 


dfaf 


DACK False to ACK False (REQ False) 






90 


ns 


dfdt 


DACK False to DRQ True 


30 


90 




ns 


dhr 


Data Hold from End of Read Enable (Notes 1,2) 


20 




60 


ns 


dhra 


SCSI Data Hold from REQ True 


15 






ns 


dkhr 


DACK Hold from End of RD 









ns 


dsra 


SCSI Data Setup Time to REQ True 


10 






ns 


dtdf 


DACK Tme to DRQ False 






45 


ns 


eop 


Width of EOP Pulse (Note 3) 


25 






ns 


rfaf 


REQ False to ACK False (DACK False) 






90 


ns 


rtat 


REQ True to ACK True 






80 


ns 


rtdt 


REQ True to DRQ True 






70 


ns 



o 
■o 

OS 

<o 

o 



El 



Note 1: Read enable (DMA) is DACK and RD active. 

Note 2: This includes tile RC delay Inherent In the test's method. These signals typically turn off after 25 ns enabling other devices to drive these lines with no 
contention. 

Note 3: EOP, DACK, RD/WR must all be true for recognition of EOP. 
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12.0 AC Electrical Characteristics (continued) 

12.9 DMA WRITE (BLOCK MODE) TARGET SEND 



DRQ 



y 



l^dtdf-H 



DACK 



^. 



WR 



\. 



D0..7 



- dswd - 



J^ 



\ 



-dhwr- 



Byte n+1 



EOP 



REQ 



ACK 



""^^ 



READY 



-atrf- 



-eop~ 



^^ 7' 



3^ 



j^ 



-atrt- 



.^ 



-wfrf- 



.^ 



\ 



-dhat- 



DB0..7,P 



Byte n 



-dsrt- 



>P 



Byte n*1 



Symbol 


Parameter 


DP8496 


Units 


MIn 


Typ 


Max 




afrt 


ACK False to REQ True (DACK or WR False) 






75 


ns 


atrf 


ACK True to REQ False 






100 . 


ns 


atrt 


ACK True to READY True 






50 


ns 


dhat 


SCSI Data Hold from ACK True 


40 






ns 


dhwr 


DMA Data Hold Time from End of WR 


10 






ns 


dsrt 


SCSI Data Setup to REQ Taie 


35 






ns 


dswd 


Data Setup to End of DMA Write Enable (no juP Parity) 
(Note1) (with jiP Parity) 


35 
35 






ns 
ns 


dtdf 


DACK True to DRQ False 






45 


ns 


eop 


Width of EOP Pulse (Note 2) 


25 






ns 


rtwf 


READY True to WR False 


40 






ns 


wfrf 


WR False to READY False 






50 


ns 


wfrt 


WR False to REQ True (ACK False) 






80 


ns 


wwb 


DMA Write Enable Width (Note 1) 


40 






ns 



Note 1: Write enable 
Note 2: EOP, DACK, 



(DMA) is DACK and WR active. 

RD/WR must all tie true for recognition of EOP. 
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12.0 AC Electrical Characteristics (continued) 

12.10 DMA WRITE (BLOCK MODE) INITIATOR SEND 



DRQ 



y 



l—dWf-. 



DACK 



■^L. 



-wwb- 



WR 



■^L 



D0..7 



EOP 



J^ 



rtat 



ACK 



"^^ 



rtyt 



READY 



.^ 



-dswd- 



J^ 



\ 



-dhwr- 



Byte n + 1. 



-eop- 



^^ 7' 



3C 



wfaf 



J 



\ 



dhl 



^^ 



DB0..7, P 



Byte n 



3C 



X 



Byte n+1 
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Symbol 


Parameter 


DP8490 


Units 


Min 


Typ 


Max 


dhl 


SCSI Data Hold from Write Enable 


15 






ns 


dhwr 


DMA Data Hold Time from End of WR 


10 






ns 


dswd 


Data Setup to End of DMA Write Enable (no ftP Parity) 
(Note1) (with ;iP Parity) 


35 
35 






ns 
ns 


dtdf 


DACK True to DRQ False 






45 


ns 


eop 


Width of EOP Pulse (Note 2) 


25 






ns 


rfyt 


REQ False to READY True 






60 


ns 


rtat 


REQ True to ACK True 






80 


ns 


rtwf 


READY True to WR False 


40 






ns 


wfaf 


WR False to ACK False (REQ False) 






95 


ns 


wfrf 


WR False to READY False 






50 


ns 


wwb 


DMA Write Enable Width (Note 1 ) 


40 






ns 



o 

OS 



a 



Note 1: Write enable (DMA) Is DACK and WR active. 

Note 2: EOP. DACK. RD/WR must all be true for recognition of EOP. 
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12.0 AC Electrical Characteristics (continued) 

12.11 DMA WRITE (BLOCK MODE) TARGET RECEIVE 



DRQ 



y 



DACK 



■^^ 



WR 



A. 



-dtdf- 



■^^ 



ddv 



D0..7 



J^ 



-dhr- 



3C 



Byte n 



EOP 



REQ 



— eop — 



ACK 



-atrf- 



7^ 



^^ 



— atyt- 



READY 



DB0..7.P 



■• dsra ► 



-rydv- 



-afrt- 



y 



-rfyf- 



J^ 



-"^ 



-dhra- 



Byle n 



3( 



\ 
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Symbol 


Parameter 


DP84gO 


Units 


Min 


Typ 


Max 


afrt 


ACK False to REQ True (DACK or WR False) 






75 


ns 


atrf 


ACK True to REQ False 






100 


ns 


atyt 


ACK True to READY True 






50 


ns 


ddv 


DMA Data Valid from Read Enable (Note 1 ) 






40 


ns 


dhr 


Data Hold from End of Read Enable (Notes 1 ,2) 


20 




60 


ns 


dhra 


SCSI Data Hold from ACK True 


15 






ns 


dsra 


SCSI Data Setup Time to ACK Tme 


10 






ns 


dtdf 


DACK True to DRQ False 






45 


ns 


eop 


Width of EOP Pulse (Note 3) 


25 






ns 


rfrt 


RD False to REQ True (ACK False) 






75 


ns 


rfyf 


RD False to READY False 






45 


ns 


rydv 


READY True to Data Valid 






20 


ns 



Note 1: Read enable (DMA) is DACK and RD active. 

Note 2: This includes the RC delay inherent in the test's method. These signals typically turn off after 25 ns enabling other devices to drive these lines with no 

contention. 

Note 3: EOP, DACK, RD/WR must all be active for recognition of EOP. 
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12.0 AC Electrical Characteristics (continued) 

12.12 DMA READ (BLOCK MODE) INITIATOR RECEIVE 



ORQ 



f 



DACK 



^^ 



RD 



\. 



D0..7 



EOP 



REQ 



■^^ 



ACK 



READY 



DBO.J.P 



dsra 



-dtdf- 



\ 



ddv 



f 



-dhr- 



Byte n 



y< 



-e(^- 



^^ / 



f 



-rtat 



^^ 



rtyt 



« rydv - 



-rfaf- 



-rdaf- 



j'' 



-rfyf- 



J^ 



\ 



-dhra- 



Byte n 



% 



Symbol 



ddv 



dhr 



dhra 



dsra 



dtdf 



eop 



rdaf 



rfaf 



rfyf 



rtat 



rtyt 



rydv 



Parameter 



DMA Data Valid from Read Enable (Note 1) 



Data Hold from End of Read Enable (Notes 1,2) 



SCSI Data Hold from REQ True 



SCSI Data Setup Time to REQ True 



DACK True to DRQ False 



Width of EOP Pulse (Note 3) 



RD False to ACK False (REQ False) 



REQ False to ACK False (DACK False) 



RD False to READY False 



REQ True to ACK True 



REQ True to READY True 



READY True to Data Valid 



DP8490 



Min 



20 



15 



10 



25 



Note 1: Read enable (DMA) Is DACK and RD active. 

Note 2: This Includes the RC delay Inherent In the tes 

contention. 

Note 3; EOP, DACK, RD/WR must all be active for recognition of EOP. 



Typ 



Max 



40 



60 



45 



120 



90 



45 



80 



65 



20 



\ 



\ 



TL/F/9387-25 



Units 



Note 2: This Includes the RC delay Inherent In the test's method. These signals typically turn off after 25 ns enabling other devices to drive these lines with no 
contention. 
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Appendix A1 

Arbitration & (Re)Selection 



R«s«t 
MR2ARB 



Set 



No 



ODR = device ID 



Set MR2:ARB 
(bit 0) 




Walt BUS FREE + 

ARBITRATION Delays 

(800 * 2200 ns) 




Read CSD and resolve 
ID priorities 




Set ICR:ASS_SEL 
(bR2) 



Wait BUSCLEAR + 

BUS SETTLE delays 

(800 + 400 ns) 




- Selection 



Set MR2: TARGET 

MODE (Bit 6) 

SetTCR:ASS_l/0 

(bftO) 



I 



(Normal Mode) 



I 





ODR = device 

ID OR'd 
wKh controller 






SELECTION 


>^ 


RESELECnON 




I 


\^ 


^^,_^ 


SetlCR:DBUS, 
ATN,SEL(Bits 0,1,2) 




SetlCR:DBUS, 1 
SEL (Bits 0,1) 1 














i 








Ensure SER = 

Reset MR2:ARB 

(Bit 0) 




< 


^^KY actlve^*V 

wHhin SELECTION 
. TIMEOUT DEUY ^ 
\j250ni^X''^ 


>^ 




SELECTION 


( Error 

RESELECTtO^ 


rogllne ) 

[ 


. 


"^^ 


1 


Reset ICR:DBUS,Sa 
(Bits 0,2) 


|setlCR:BSY(Blt3)| 








SetlCR:DBUS, 1 
SEL (Bits 0.2) 1 











Information 
Transfer Phases 



*Only set ATN if Select with ATN is desired. 



TLyF/9387-27 



TL/F/9387-26 
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Appendix A1 (continued) 



Arbitration & (Re)Selection 



(Enhanced Mode) 



O 
OS 

o 





ODR = device ID | 






. 








\\ 






SetEMR:ARB 1 
(bit 0) 1 






, , 








Do other tasks while 
waiting for Interrupt 


Reset 

EVIR:ARB 






^(Interrupt) 


i 










Read ISR, check ARB 
Complete (Bit 0) Is set 
Set EMR:ErN = 01 
(BHs 2,1) to reset interrupt 
SelEMR:EFN = OOto 
remove Interrupt reset 




Set 


^^^^1 hock 


iCR LA^ 

Reset 

• 


1 


1 








Read CSD and resolve 

priorities 




No 




.^^J^\% devloe^^. 



! highest 



Set ICR;ASS_SEL 
(bH2) 



Walt BUS aEAR + 

BUS SETTLE delays 

(800 + 400 ns) 




Target? 



No^- Selection 



Yes-TReselection 



Set MR2: TARGET 

MODE (Bit 6) 

SetTCR:ASSJ/0 

(bit 0) 



1 
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Appendix A1 (continued) 



Command Transfer (initiator) 



Set MR2:BSY(btt2) 
SetTCR:C/D(bR1) 




;=3 — , 

^^ Phaw Error J 



ODR = Command byte 

Set ICR:Asset_ACK 

(bn4) 




*This step unnecessary in MODE E if the EMR : 
APHS (bit 7) is enabled. Logic automatically 
checks the phase on any transfer and interrupts 
on an error. 
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Appendix A1 (continued) 



Command Transfer 



(Target) 

— ► 



Mas9ag«_out 
Phas* 




I SatTCR:C/D(bH t) I 

i 



Walt Bus Settle Delay 
SetTCR:ASS_REQ (bit 3) 




Command = CSD 
(Parity checked if enabled) 



T 



Verify Operation Code 
setup CDB length 



Reset TCR:ASS_REQ 




Transfer remaining 
CDB bytes 



TL/F/9387-30 
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Appendix A1 (continued) 

Block Mode DMA Transfer 
Initiator Receive (MODE E) 



Program DMA Controller with block 

longth, start address and n^emory 

write operation 



TCR = 01h;ICR = 40h; MR2 = BEh 




Reset DMA Mode 
(MR2 = 04ti) 



Q Error routine ) 



Block Mode DMA Transfer 
Target Send (MODE E) 



Program DMA Controller with block 

length, start address and memory 

write operation 



TCR = 01h; ICR = 39h; MR2 = CAh ^ 



SOS = XX to Start DMA Send 




Road ISR for Intorrupt status | 




Reset DMA Mode 
(MR2 = 04h) 



Error routine 



TL/F/9387-32 
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Appendix A2 



Btt7 



Read 
Current SCSI Data (CSD) 



Register Chart 



BitO 



DB7 


DB6 


DBS 


DB4 


DBS 


DB2 


DB1 


DBG 


Bit? 


initiator Command Register (iCR) Bit 


R§T 


AlP 


1^ 


ACK 


BSY 


SEL 


ATN 


DBUS 


Bit 7 


Mode Register 2 (MR2) BitO 


BLK 


TARG 


PCHK 


PINT 


EOP 


BSY 


DMA 


ARB 


Bit 7 


Target Command Register (TCR) Bit 














REQ 


MSG 


C/D 


ITS 


Bit 7 


Current SCSi Bus Status (CSB) BitO 


RST 


BSY 


REQ 


MSG 


C/D 


170 


SEL 


DBP 


Bit? 


Bus and Status Register (BSR) Bit 


EDMA 


DRQ 


SPER 


INT 


PHSM 


BSY 


ATN 


ACK 


Bit? 


input Data Register (iDR) BitO 


DB7 


DB6 


DBS 


DB4 


ms 


DB2 


DB1 


DBG 



Bit? 




Reset Parity/interrupt 
(RPi)— MODEN 




BitO 


X 


X 


X 


X 


X 


X 


X 


X 


Bit? EniiancediUode Register (EiUIR) BitO 


APHS 


MPEN 


MPOL 


SPOL 


LOOP 


EFN1 


EFNG 


ARB 


Bit? interrupt Status Register (iSR) BitO 


SPE 


MPE 


EDMA 


DPHS 


APHS 


BSY 


SEL 


ARB 


Target Command Register 
Bit? (TCR)— lUODEE BitO 


(true) 
EDMA 


G 








REQ 


MSG 


C/D 


l/Q 



Write 



Bit? 




Output Data Register (ODR) 




BitO 


DB7 


DB6 


DBS 


DB4 


D63 


DB2 


DB1 


DBG 


Bit? initiator Command Register (iCR) BitO 


RST 


MODE 

E 


DIFF 
EN 


ACK 


BSY 


SEL 


ATN 


DBUS 


Bit? Mode Register 2 (iUR2) BitO 


BLK 


TARG 


PCHK 


PINT 


EOP 


BSY 


DMA 


ARB 


Bit 7 Target Command Register (TCR) Bit 


X 


X 


X 


X 


REQ 


MSG 


C/D 


170 


Bit? SeiectEnabie Register (SER) BitO 


DB7 


DB6 


DBS 


DB4 


DB3 


DB2 


dbT 


DBG 


Bit? Start DMA Send (SDS) BitO 


X 


X 


X 


X 


X 


X 


X 


X 


Start DMA Target Receive 
Bit? (SDT) BitO 


X 


X 


X 


X 


X 


X 


X 


X 


Start DMA Initiator Receive 
Bit? (SDi)— MODEN BitO 


X 


X 


X 


X 


X 


X 


X 


X 


Bit? Eniianced Mode Register (EMR) BitO 


APHS 


MPEN 


MPOL 


SPOL 


LOOP 


EFN1 


EFNC 


) ARB 


Bit? interrupt Masic Register (IMR) BitO 


SPE 


MPE 


EDMA 


DPHS 


APHi 


3 BSY 


SEL 


ARB 


Target Command Register 
Bit? (TCR)— MODE E BitO 


X 


X 


X 


X 


REQ 


MSG 


CTd 


170 



X = Don't Care 



X = Unknown 
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DP5380 Asynchronous SCSI Interface (ASi) 



General Description 

The DP5380 ASI is a CMOS device designed to provide a 
iow cost, higli performance Smail Computer Systems Inter- 
face. It complies with the ANS X3.131-1986 SCSI standard 
as defined by the ANSI X3T9.2 committee. It can act as 
both INITIATOR and TARGET, making It suitable for any 
application. The ASI supports selection, reselectlon, arbitra- 
tion and all other bus phases. High-current open-drain driv- 
ers on chip reduce application chip count by interfacing di- 
rect to the SCSI bus. An on-chip oscillator provides all tim- 
ing delays. 

The DP5380 is pin and program compatible with the NMOS 
NCR5380 device. NCR5380 or AM5380 applications can 
use it with no changes to hardware or software. The 
DP5380 is available In a 40-pin DIP or a 44-pin PCC. 
The ASI is intended to be used in a microprocessor based 
application, and achieves maximum performance with a 
DMA controller. The device is controlled by reading and 
writing several internal registers. A standard non-multi- 
plexed address and data bus easily fits any \)P environment. 
Data transfers can be performed by programmed-l/0, pseu- 
do-DMA or via a DMA controller. The ASI easily interfaces 



to a DMA controller using normal or Block Mode. The ASI 
can be used in either a polled or interrupt-driven environ- 
ment. 

Features 

SCSI Interface 

■ Supports TARGET and INITIATOR roles 

■ Parity generation with optional checking 

■ Arbitration support 

■ Direct control/monitoring of all SCSI signals 

■ High current outputs drive SCSI bus directly 

■ Faster and improved timing 

■ Very low SCSI bus loading 

^9 Interface 

■ Memory or l/O-mapped control transfers 

■ Programmed-I/O or DMA data transfers 

■ Normal or Block-mode DMA 

■ Fast DMA handshake timing 



Connection Diagram 



MPU 
BUS 



D0..7< 



AO- 
A1- 
A2- 




DP5380 



Asynchronous 
SCSI Interfacs 



(ASI) 



SCSI 
BUS 



> DB0..7,DBP 



>RST 
>BSY 
>SEL 



•-REQ 
►175 

► cTd 
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1.0 Functional Description 

1.1 OVERVIEW 

The ASI is designed to be used as a peripheral device in a 
fiP-based application and appears as a number of read/ 
write registers. Write registers are programmed to select de- 
sired functions. Status registers provide indication of operat- 
ing conditions. 

For best performance a DMA controller can be easily inter- 
faced directly to the ASI. The ASI provides request/ac- 
l^nowledge and wait-state signals for the DMA interface. 
The SCSI bus Is easily controlled via the ASI registers. Any 
bus signal may be asserted or deasserted via a bit in the 
appropriate register, and the state of every signal is avail- 
able by reading registers. This direct control over SCSI sig- 
nals allows the user to implement all or part of the protocol 
in firmware. The ASI provides hardware support for much of 
the protocol. 

The ASI provides the following SCSI support: 

• Programmed-l/0 transfers for all eight information trans- 
fer types, with or without parity. 

• Data transfers via DMA, in either block or non-block 
mode. The DMA interface supports most devices. 

Data Address 

4^ 



• Individual setting/resetting and monitoring of every SCSI 
bus signal. 

• Automatic release of the bus for BSY loss from a TAR- 
GET, SCSI RST, and lost arbitration. 

• Automatic bus arbitration— the jiP has only to check for 
highest priority. 

• Selection or Reselection of any bus device. The ASI will 
respond to both Selection and Reselection. 

• Optional automatic monitoring of the BSY signal from a 
TARGET with an interrupt after releasing control of the 
bus. 

Figure 1 shows an ASI in a typical application, a low cost 
embedded SCSI disk controller. In this application the 8051 
single-chip jiP acts as the controller and the dual DMA 
channels in the DP8475 allow one for the disk data and the 
other for SCSI data. The PAL® provides chip selection as 
well as determining who has control of the bus. The advan- 
tap'. of using a /xP with on-board ROM is that there Is more 
fiee time on the external bus. 



O 
"O 
U1 
M 
0» 
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EPROM 
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Utch 
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+ 
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FIGURE 1. ASI Application 
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1.0 Functional Description (continued) 

1.2 (aP interface 

Figure 2 shows a block diagram of the ASI. Key blocks with- 
in the ASI are Read/Write registers with associated decode 
and control logic, Interrupt and DMA logic, SCSI bus arbitra- 
tion logic, SCSI drivers/receivers with parity and the SCSI 
data input and output registers. The ASI has three interfac- 
es, one to SCSI, one to a DMA controller and the third to a 
(iP. The internal registers control all operations of the ASI. 
The fiP Interface consists of non-multiplexed address and 
data busses with associated control signals. Address de- 
code logic selects a register for reading or writing. The ad- 
dress lines AO-2 select the register for jiP accesses while 
for DMA accesses the address lines are Ignored. 
The register bank consists of twelve registers mapped Into 
an address space of eight locations. Upon an external chip 
reset the registers are cleared (all zeroes). 

1.3 DMA INTERFACE 

The DMA logic interfaces to single-cycle, block mode, flow- 
through or fly-by controll ers. Sin gle byte transfers are ac- 
complished via the DRQ/DACK handshake signals. Block 



mode transfers use the READY output to co ntrol the speed 
(insert wait-states). An End Of Process (EOP) input from the 
DMA controller signals the ASI to halt DMA transfers. An 
Interrupt can be generated for DMA completion or an error 
(see Section 5.0). All DMA data passes through the SCSI 
data input and output registers, automatically selected dur- 
ing DMA cycles. 

1.4 SCSI INTERFACE 

The ASI contains all logic required to Interface directly to the 
SCSI bus. Direct control and monitoring of all SCSI signals 
Is provided. The state of each SCSI signal may be deter- 
mined by reading a register which continuously reflects the 
state of the bus. Each signal may be asserted by writing a 
ONE to the appropriate bit. 

The ASI Includes logic to automatically handle SCSI timing 
sequences too fast for /nP control. In particular there Is 
hardware support for DMA transfers, bu s arb itration, selec- 
tion/reselectlon, bus phase monitoring, BSY monitoring for 
bus disconnection, bus reset and parity generation and 
checking. 
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FIGURE 2. ASI Block Diagram 
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1.0 Functional Description (Continued) 

The ASI arbitration logic controls arbitration for use of the 
SCSI bus. The jiP programs the SCSI device ID into the 
ASI, then sets the ARBITRATE bit. The INITIATOR COM- 
MAND REGISTER (ICR) is read to determine when arbitra- 
tion has started and whether It Is won or lost. 
The BSY signal is contlnously monitored to detect bus dis- 
connection and bus free phases. The ASI incorporates an 
on-board oscillator to determine Bus Settle, Bus Free and 
Arbitration Delays. The oscillator tolerance guarantees all 
timing to be within the SCSI specification. 

2.0 Pin Descriptions 



The ASI incorporates high-current drivers and SCHMITT 
trigger receivers for interfacing directly to the SCSI bus. This 
feature reduces the chip count of any SCSI application. 

1.5 PARITY 

The ASI provides for parity protection on the SCSI interface. 
The data bus has eight data bits and one parity bit. The 
parity may be enabled via a register bit. A parity error can be 
programmed to cause an intermpt. 



Symbol 



CS 



AO . . . 2 



m 



WR 



RESET 



DO. ..7 



INT 



DrQ 



DACK 



DIP 



21 



30, 32, 33 



24 



29 



28 



1,40-34 



23 



22 



PCC 



24 



33, 36, 37 



27 



32 



31 



2, 44-38 



26 



25 



READY 



iCP 



DBO . . . 7 
0BP 



RST 



B§7 



SEC 



aCk 



ATN 



26 



25 



27 



9... 2, 10 



16 



13 



12 



14 



15 



29 



Type 



I/O 



28 



30 



10. ..3,11 



18 



15 



14 



16 



17 



Function 



Chip Select: an active low enable for read or write operations, accessing the register 
selected by AO . . . 2. 



Address 0. . . 2: these three signals are used with CS, RD, and WR to address a 
register for read or write. 



Read: an active low enable for reading an internal register selected b y AO . . . 2 and 
enabled by 55. It also selects the Input Data Register when used with DACK. 



Write: an active low enable for writing an internal register selected by AG ... 2 and 
enabled by CS. It also selects the Output Data Register when used with DACK. 



Reset: an active low input with a Schmitt trigger. Clears ail Internal registers. (SCSI 
RST unaffected). 



Data 0. . . 7: bidirectional TRI-STATE® signals connecting the active high ftP data 
bus to the internal registers. 



Interrupt: an active high output to the nP when an error has occurred, an event 
requires service or has completed. 



DMA Request: an active high output asserted when the data register is ready to read 
or written. DRQ occurs only if DMA mode is enabled. The signal is cleared by DACK. 



I/O 



I/O 



I/O 



I/O 



I/O 



I/O 



DMA Acknowledge: an active low in put tha t resets DRQ and addresses the data 
registers for input or output transfers. DACk is used instead of CS by the DMA 
controller. 



Ready: an active high output used to control the speed of block mode DMA transfers. 
Ready goes active when the chip is ready to send/receive data and remains inactive 
after the transfer until the byte is sent or until the DMA mode bit is reset. 



End Of Process: an active low signal that terminates a block of DMA transfers. It 
should be asserted during the transfer of the last byte. 



DBO ... 7, DBP: SCSI data bus with parity. DB7 is the MSB and is the highest priority 
during arbitration. Parity Is ODD. Parity is always generated and can be optionally 
checked. Parity is not valid during arbitration. 



Reset; SCSI reset, monitored and can be set by ASI. 



Busy: indicates the SCSI bus is being used. Can be driven by TARGET or 
INITIATOR. 



Select: used by the INITIATOR to select a TARGET or by the TARGET to reselect an 

INITIATOR. 



Acknowledge: driven by the INITIATOR and received by the TARGET as part of the 
REQ/ACK handshake. 



Attention: driven by the INITIATOR to indicate an attention condition to the 
TARGET. 



O 
"O 
cn 
<•> 
OS 
o 
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2.0 Pin Descriptions (continued) 



Symbol 



DIP 



PCC 



Type 



Function 



re5 



20 



22 



I/O 



Request: driven by the TARGET and received by the INITIATOR as part of the REQ/ 
ACK handshake. 



175 



17 



19 



I/O 



Input/Outpub driven by the TARGET to control the direction of transfers on the 
SCSI bus. This signal also distinguishes between selection and reselection. 



57d 



18 



20 



I/O 



Command/Data: driven by the TARGET to indicate whether command or data bytes 
are being transfened. 



RiSS 



19 



21 



I/O 



Message: driven by the TARGET during message phase to identify message bytes 
on the bus. 



VCC 
GND 



31 
11 



35 
12.13 



VCC, GND: + 5V DC is required. Because of very large switching cun-ents good 
decoupling and power distribution is mandatory. 



2.1 Connection Diagrams 



DO- 

6b7- 

DB6- 
085- 

oSi- 

DW- 

DB2- 
DBt- 
DBO- 
DBP- 
OiD- 
SEL- 

Bsr- 
Jai- u 
Xfii- 15 

RST- 16 

i75- 17 

^- 18 

MS6 



40 -D1 
39 -02 



-03 
-04 
-05 
D6 
-07 
-A2 
-A1 

-Vce 
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-WR 
RESET 

-top 
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-INT 
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Order Number DP5380N 
See NS Package Number N40A 
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39 
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8 


38 
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D§i- 


9 


37 


-A2 




m- 


\ 


36 


-A1 




m- 




35 


-Vcc 


Order Number DPS380V 


GNO- 
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34 




See NS Package Number V44A 
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33 


-AO 




^- 




32 


-WR 
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31 


-RESET 
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-EOP 
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3.0 Register Description 

3.1 GENERAL 

The DP5380 ASI is a register-based device with eight ad- 
dressable locations. Some addresses have dual functions 
depending upon whether they are being read from or written 
to. Device operation is described in Section 4. 
Figure d.^ summarises the register map. Note that for regis- 
ters reading or writing SCSI signals the SCSI name is used 
for each bit. Although the SCSI bus Is active low the regis- 
ters invert the SCSI bus. This means an active SCSI signal 
is represented by a ONE in a register and an inactive signal 
by a ZERO. 

3.2 REGISTERS 

OUTPUT DATA REGISTER (ODR) 
8 Bits HA Write-Only 

This is a transparent latch used to send data to the SCSI 
bus. The register can be written by ftP cycles or via DMA. 
DMA writes automatically select the ODR at Hex Address 
(HA 0). This register is also written with the ID bits required 
during arbitration and selection/reselection phases. Data is 
latched at the end of the write cycle. 



Bit 7 














BItO 


DB7 


DB6 


DBS 


DB4 


DBS 


DB2 


DBl 


DBO 



Output Data Register 

CURRENT SCSI DATA (CSD) 
8 Bits HA Read-Only 

This register enables reading of the current SCSI data bus. 
If SCSI parity checking is enabled it will be checked at the 
beginning of the read cycle. The register is also used for fiP 
accesses of SCSI data during programmed-l/0 or ID check- 
ing during arbitration. Parity is not valid during arbitration. 
DMA transfers select the IDR (HA 6) instead of the CSD 
register. 



Bit 7 














BItO 


057 


DB6 


DB5 


DB4 


DBS 


DB2 


DB1 


DBO 



Current SCSI Data 



INITIATOR COIUMAND REGISTER (ICR) 
8 Bits HA 1 Read-Write 

This register is used to control the INITIATOR and some 
other SCSI signals, and to monitor the progress of bus arbi- 
tration. Most of the SCSI signals may als o be asserted in 
TARGET mode. Bits 5 to are reset when BSY is lost (see 
MR2 description). 



Bit 7 














BItO 


RST 


TEST 


UV/DIFF 


A5K 


BSY 


SCL 


ATN 


DBUS 



Initiator Command Register 



BitO 



DBUS: Assert Data Bus 

Disable SCSI data bus driving. 

1 Enable contents of Output Data Register onto the SCSI 
data bus. SCSI parity is also generated and driven on 
DBP. 

This bit should be set when transfening data out of the ASI 
in either TARGET or INITIATOR mode, for both DMA or 
programmed-l/0. In INITIATOR mode the drivers are only 
enabled if: Mod e Reg ister 2 TA RGET MODE t)it is 0, and 
170 is false, and C/D, I/O, MS5 match the contents of the 
Target Command Register (phasematch is true). In TAR- 
GET mode only the MR2 bit needs to be set with this bit. 
Reading the ICR reflects the state of this bit. 
ATN: Assert Attention Bit 1 

Deassert ATN. 

1 Assert SCSI ATN signal. The MR2 TARGET MODE bit 
must also be false to assert the signal. 

Reading the ICR reflects the state of this bit 

SEL: Assert Select Bit 2 

Deassert SEC. 

1 Assert SCSI SEC signal. Can be used in INITIATOR or 
TARGET mode. 

Reading the ICR reflects the state of this bit. 

§SY: Assert Busy Bit 3 

Deassert BSY. 

1 Assert SCSI 557 signal. Can be used in INITIATOR or 
TARGET mode. 

Reading the ICR reflects the state of this bit 



Hex 
Adr 


Register 


Mnemoi 





Output Data Register 


ODR 





Current SCSI Data 


CSD 


1 


Initator Command Register 


ICR 


2 


Mode Register 2 


MR2 


3 


Target Command Register 


TCR 


4 


Select Enable Register 


SER 


4 


Current SCSI Bus Status 


CSB 


5 


Bus and Status 


BSR 


5 


Start DMA Send 


SDS 


6 


Start DMA Target Receive 


SDT 


6 


Input Data Register 


IDR 


7 


Start DMA Initiator Receive 


SOI 


7 


Reset Parity/intenxipts 


RPI 



Bite 



R/W 



8 


WO 


8 


RO 


8 


RW 


8 


RW 


4 


RW 


8 


WO 


8 


RO 


8 


RO 





WO 





WO 


8 


RO 





WO 





RO 



FIGURE 3.2. Registers 
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3.0 Register Description (continued) 

ACK: Assert Acknowledge Bit 4 

Deassert ACK. 

1 Assert SCSI ACK signal. The MR2 TARGET MODE bit 
must also be false to assert the signal. 

Reading the ICR reflects the state of this bit. 
DIFF: Differential Enable Bits Write 

This bit must be reset to 0. 

1 Do not use. Reserved for future use on a differential 
pair device. 

IJV: Lost Arbitration Bits Read 

Normally reset to to show arbitration not lost or not 
enabled. 

1 Will be set when the ASI loses arbitatlon, i.e. w hen SEL 
Is true during arbitration AND the Assert SEL bit of this 
register Is false. 

A 1 In t his bi t means the ASI has arbitrated for the bus, 
asserted BS Yand Its ID on the data bus and another device 
has asserted SEE. The ARBITRATE bit in MR2 must be set 
to enable arbitration. 
TEST: Test Mode Enable Bits Write 

Output drivers are enabled. 

1 Output drivers disabled. 

AiP: Arbitration In Progress Bit 6 Read 

Normally to show no arbitration In progress. 

1 Set when the ASI has detected BUS FREE phase and 
s^serted BSY and the Output Data Register contents 
onto the SCSI data bus. This bit remains set until arbi- 
tration is disabled. 

fiST: Assert RST Bit? 

Deassert RST. 

1 Assert SCSI RST signal. RS T Is asse rted as long as this 
bit is 1, or until a jiP Reset (RESET). 

After this bit is set the INT pin goes active and internal regis- 
ters reset (except for the Inten'upt latch, MR2 TARGET 
MODE bit, and this bit. Reading the ICR reflects the state of 
this bit. 

MODE REQISTER 2 (INR2) 
8 Bits HA2 Read-Write 
This register is used to program basic operating conditions 
in the ASI. Operation as TARGET or INITIATOR, DMA 
mode and type as well as some Interrupt controls are set via 
this register. This Is a Read/Write register and when read 
the value reflects the state of each bit. 



Bit 7 














BitO 


BLK 


TARG 


PCHK 


PINT 


EOP 


BSY 


DMA 


ARB 



Mode Register 2 



BitO 



ARB: Arbitrate 

Disable arbitration. 

1 Enable arbitration. The ASI will wait for a BUS FREE 
phase then arbitrate for the bus. Before setting this bit 



the Output Data Register should contain the SCSI de- 
vice ID--a single bit set only. The status of the arbitra- 
tion process is given in the AIR and LA bits (6, 5) in the 
Initiator Command Register. 
DMA: DMA Mode Bit 1 

Disable DMA mode. 

1 Enable DMA operation. This bit should be set then one 
of address 5 to 7 written to start DMA. The TARGET 
MODE bit in the ICR and the phase lines in the TCR 
should have been set appropriately. The DBU S bH in 
the ICR must be set for DMA operations. BSY must be 
active in order to set this bit. The phase lines must 
match the contents of the TCR during the actual trans- 
fere. InDMA mode ASI logic automaticeilly controls the 
REQ/aCk handshakes. 

This bit shou ld be reset by a ii,P write to stop any DMA 
transfer. An EOP si gnal will not reset this bit. During 
DMA, SS and DACK should not be active simultaneous- 
ly- 

This bit will be reset if BSY Is lost during DMA mode. 
BSY: Monitor Busy Bit 2 

Disable BSY monitor. 

1 Monitor SCSI BSY signal and internjpt when BSY goes 
inactive. When this bit goes active the lower 6 bits of 
the ICR are reset and all signals removed from the 
SCSI bus. This is used to check for valid TARGET con- 
nection. 

EOP: Enable 15P interrupt Bits 

No Interrupt for EOP. 

1 Interrupt after valid EOP condition. 

PINT: Enable SCSI Parity Interrupt Bit 4 

No intermpt on SCSI parity error. 

1 When SCSI parity Is enabled via the PCI-IK bit, setting 
this bit enables an Interrupt upon a SCSI parity error. 

PCHK: Enable SCSI Parity Cheeidng Bits 

No SCSI parity checking. 

1 Enable checking of SCSI parity during read operations. 
This applies to either programmed I/O or DMA mode. 

TARG: Target Mode Bit 6 

Initiator Mode. 

1 Target Mode. 

BLK: Block Mode DMA Bit? 

Non-block DMA. 

1 When set along with DMA bit (1) enable block mode 
DMA transfers. In block mode the READY line is used 
to handshake ea ch byte with the DMA controller in- 
stead of the DRQ/DACK handshake used in non-block 
mode. 

TARGET COMMAND REGISTER (TCR) 

4 Bits HA 3 Read-Write 

This register Is used to control TARGET SCSI signals and to 

program the desired phase during INITIATOR mode. During 
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3.0 Register Description (continued) 

DMA transfers the SCSI phase lines (C/D, MSG, ITD) must 
match the contents of the TCR for transfers to occur. A 
phase mismatch halts DMA transfers and generates an in- 
terrupt. 



Bit 7 














BitO 


X 


X 


X 


X 


REQ 


MSG 


C/D 


ITD 



Target Command Register 

This is a read/write register and the value read reflects the 
state of each bit, except bit 4-7 which always read 0. 
170: Assert 170 BitO 

Deassert ITO. 

1 Assert SCSI ITQ signal. The MR2 TARGET MODE bit 
must also be active. 

C76: Assert CTD Bit1 

Deassert CTD. 

1 Assert SCSI CTD signal. The MR2 TARGET MODE bit 
must also be active. 

MSS: Assert MSG Bit 2 

Deassert MSG. 

1 Assert SCSI MSG signal. The MR2 TARGET MODE bit 
must also be active. 

REQ: Assert REQ Bits 

Deassert REQ. 

1 Assert SCSI REQ signal. The MR2 TARGET MODE bit 
must also be active. This bit Is used to handshal<e SCSI 
data via programmed-l/0. 

SELECT ENABLE REGISTER (SER) 

8 Bits HA 4 Write-Only 

This write-only register is used to program the SCSI device 

ID for the ASI to respond to during Selection or Reselection 

Phas es. On ly on e bit in the register should be set. When 

SEL is true, BSY false and the SER ID bit active an interrupt 

will occur. 

This interrupt is reset or can be disabled by writing zero to 
this register. Parity will also be checked during Selection or 
Reselection if the PCHK bit in MR2 is set. 



Bit 7 














BitO 


DB7 


DB6 


DBS 


DB4 


DB3 


DB2 


DB1 


DBO 



Select Enable Register 

CURRENT SCSI BUS STATUS (CSB) 
8 Bits HA 4 Read-only 

This read-only register is used to monitor SCSI control sig- 
nals and the SCSI parity bit. The SCSI lines are monitored 
during programmed-l/O transfers and after an internjpt in 
order to determine the cause. A bit is 1 if the corresponding 
SCSI signal is active. 



Bit 7 














BitO 


rSt 


BSY 


REQ 


MSG 


C/D 


170 


SEL 


DBP 



BUS AND STATUS REGISTER (BSR) 
8 Bits HA 5 Read-only 

This read-only register is used to monitor SCSI signals not 
included in the CSB, and internal status bits. This register is 
read after an intermpt to determine the cause of an inter- 
rupt. Bit or 1 are set to 1 If the SCSI signal is active. 



Bit 7 














BItO 


EDMA 


DRQ 


SPER 


INT 


PHSM 


BSY 


ATN 


ACK 



Bus & Status Register 

ACK: Acknowledge Bit 

This bit reflects the state of the SCSI ACK Signal. 
ATN: Attention Bit 1 

This bit reflects the state of the SCSI ATN Signal. 
BSY: Busy Error Bit 2 

No Error. 

1 This SCSI BSY sig nal h as become inactive while the 
MR2 BSY (Monitor BSY) bit is set. This will cause an 
interrupt, remove all ASI signals from the SCSI bus and 
reset the DMA MODE bit in MR2. 

PHSM: Phase Match Bit 3 

Phase Match. The SCSI C7D, I70 and M§G phase lines 
are continuously compared with the corresponding bits 
in the TCR. The result of this comparison is reflected in 
this bit. This bit must be 1 (phase matches) for DMA 
transfers. A phase mismatch will stop DMA transfers 
and cause an interrupt. 
INT: Interrupt Request Bit 4 

No Interrupt. 

1 Internjpt request active. Set when an enabled interrupt 
condition occurs. This bit reflects the state of the INT 
pin. INT may be reset by performing a Reset Parity/In- 
terrupt (RPI) function. 

SPER: SCSI Parity Error Bit 5 

No SCSI parity error. 

1 SCSI parity error occurred. This bit remains set once an 
error occurs until the RPI function clears it. The PCHK 
bit in MR2 must be set for a parity error to be checked 
and registered. 

DRQ: DMA Request Bit 6 

No DMA request. 

1 DMA request active. This bit reflects the sta te of the 
DRQ pin. DRQ is reset by asserting DACK during a 
DMA cycle or by resetting the DMA bit in MR2. A Busy 
error will reset the MR2 DMA bit and thus will also clear 
DRQ. A phase mismatch will not reset DRQ. 

EDMA: End of DMA Bit 7 

Not end of DMA. 



Current SCSI Bus Status 



1 Set when DACK, EOP and either RD or WR are active 
simultaneously. Normally occurs when the last byte is 
transferred by the DMA. During DMA send operations 
the last byte transferred by the D MA may not have 
been transferred on SCSI so REQ and ACK should be 
monitored to verify when the last SCSI transfer is com- 
plete. This bit is reset when the MR2 DMA bit is reset. 
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3.0 Register Description (continued) 

START DMA SEND (SDS) 

Bits HA 5 Write-Only 

This write-oniy register is used to start a DMA send opera- 
tion. A write of don't-care data siiouid be tiie last thing done 
by the juP. The IVIR2 DMA, BLK and TARG bits must have 
been programmed previously. 



zx 



X 



Bit? 












3itO 


X 


X 


X 


X 


X 


X 


X 


X 



Start DMA Send 

START DMA TARGET RECEIVE (SOT) 
Bits HA 6 Write-Only 

This write-only register is used to start a DMA Target Re- 
ceive operation. Same comments as SDS apply. 
INPUT DATA REGISTER (IDR) 
8 Bits HA 6 Read-only 

This read-only register contains the SCSI data last latched 
during a DMA receive. Each byte from SCSI is latched Into 
this r egister automatically by the ASI DMA logic. A DMA 
read (DACK and RD) automatically selects this register. Pro- 
grammed-l/0 SCSI data reads should use the CSD (HAS) 
START DMA INITIATOR RECEIVE (SDI) 
Bits HA 7 Write-Only 

This write-only register is used to start a DMA INITIATOR 
Receive Operation. Same comments as SDS apply. 
RESET PARITY/INTERRUPT (RPI) 
Bits HA 7 Read-only 
This read-only register Is used to reset the parity and inter- 
rupt latches. Reading this register resets the SCSI parity, 
Busy Loss and Interrupt Request latches. 

4.0 Device Operation 

4.1 GENERAL 

This section describes overall operation of the ASI. More 
detailed Information of data transfers, Interrupts and reset 
conditions are covered in later sections. The operation de- 
scription covers ixP accesses, SCSI bus monitoring, arbitra- 
tion, selection, reselectlon, programmed-l/0, DMA Inter- 
rupts. Programming and timing details are covered. 
For information regarding interfacing to jiP's and DMA con- 
trollers refer to Section 7.0. 

in the descriptions following program examples are given in 
pseudo-C. This processor-independent approach should be 
clearest. These are backed up by flow charts in Appendix 
A.I. 

4.2 iuP ACCESSES 

The fiP accesses the EASI via the CS, RD, WR and address 
and data lines In order to read/write the registers. Figure 4.2 
shows typical timing. Note the use of non-multiplexed ad- 
dress and data lines. 

4.3 SCSI BUS MONITORING/DRIVING 

The SCSI bus may be monitored or driven at any time. Each 
bus signal is buffered and inverted by the ASI and can be 
read via the CSB, BSR and CSD registers. An active SCSI 
reads a 1 in the status registers. 
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J- 
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(Write) 
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y. 



DC 
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FIGURE 4.2. jmP Cycles 

Each SCSI signal may be asserted by setting a bit in the 
TCR or ICR. Setting the bit to 1 asserts the SCSI signal. 
The following code demonstrates a byte transferred via pro- 
grammed-l/0 in INITIATOR mode. 

( /*Iransfer one byte as Initiator*/ 

while (NOT (ICE:REQ)) ; 

/* wait till TARGET asserts REQ */ 
data = Input (CSD) ; 

/* parity is checked if enabled*/ 
output (ICR, Assert ACiC) ; 
while (TCR:REQ) ; 

/* wait till TARGET deasserts REQ */ 
output (ICR, 0) ; 

/* deassert ACic, ready for next byte */ 



4.4 ARBITRATION 

This sub-section describes the arbitration support provided 
by the ASI and how to program It 
Since the SCSI arbitration process requires signal sequenc- 
ing too fast for juP's, hardware support is provided by the 
ASI. The artsitration process is enabled by bit MR2 (ARB). 
Prior to setting this bit the ODR should be programmed with 
the device's SCSI ID— a single bit. 

The ASI will monitor the bus for a BUS FREE phase. The 
BSY signal Is continuously monitored. If continuousl y ina c- 
tlve for at least a SCSI Bus Settle Delay (400 ns) and SEL is 
Inactive, a valid Bus Free Phase exists. After a period of 
SCSI Bus Free Delay (800 ns) the ASI asserts BSY and the 
ODR onto the SCSI data bus. The jiP should poll the ICR to 
determine when arbitration has started. The AlP bit in the 
ICR Is set when the Bus Free Phase Is detected and the 
EASI Is beginning the Bus Free Delay. Following the Bus 
Free Delay a 2.2 jis SCSI Arbitration Delay Is required be- 
fore examining the data bus to resolve the priorities of the 
ID bits. This delay must be implemented in firmware. The 
ICR Lost Arbitration (LA) bit must be examined to determine 
whether arbitration Is lost. The LA bit Is set if another 
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4.0 Device Operation (continued) 

device asserts SEL during arbitration, if tlie LA bit is the 
data bus is read via tiie CSD register. The data is examined 
to resoive iD priorities, if this device is the highest ID assert 
SEL by setting iCR bit 2 to a 1 . After waiting Bus Clear + 
Bus Settle Delays (1200 ns) the Selection Phase begins. 
These 2 delays must be implemented in firmware. 

4.5 SELECTION/RESELECTION 

The ASI can be used to select or reselect a device. The AS! 
will also respond to selection or reselection. 

4.5.1 Selecting/Reselecting 

Selection requires programming the ODR with the desired 
and own devic e ID's; the data bus via ICR DBUS (bit 0); 
asserting ATN if required via ICR bit 1 ; asserting §EL via 
ICR bit 2; then resetting the MR2 ARB bit. 
The SER should have been cleared to zero before Selec- 
tion/Reselection to ensurethe ASI does not respond. If Re- 
selection is desired the I/O line should also be asserted 
before §EL via TCR bit 0. 

Resetting the ARB bit causes the ASI to remove BSY and 
the ODR from the data bus. Thus the ICR Assert data bus 
bit is required to assert the bits for desired and own device 
ID'S. 

BSY is then monitored to determine when the device has 
responded to (re)selection. If the device fails to respond an 
en-or handler should sequence the ASI off the bus. If the 
device responds the ICR DBUS and §EL bits should be re- 
set to remove these signals. If this is a Reselection the ICR 
BSY bit (3) should be set before removing the other signals. 
The bus is now ready to handle Information Transfer Phas- 
es. 

4.5.2 (Re)Selection Response 

The ASI responds to Selection or Reselection when the 
SER is non-zero. A (re)selected Interrupt is generated when 
BSY is false for at least a Bus Settle Delay (400 ns); and 
SEE is true AND any non-zero bit in the SER has its corre- 
sponding SCSI data bus bit active. A Selection is disabled 
by zeroing the SER. If parity is supported it should be valid 
during (re)selection so must be checked via the SPE bit (5) 
in the BSR. SCSI specification states that (re)selection is 
not valid if more than 2 data bits are active. This condition is 
checked by reading the CSD. 

When the selection interrupt occurs it is determined by read- 
ing the BSR and CSB registers. There is no dedicated 
status bit for (re)selection so it must be determined b y the 
absence of other inten'upts, and the active state of the SEL 
signal. Reselection occurs when I/O is also active. See 
Section 6.0. 

4.6 MONITORING BSY 

While an INITIATOR is connected to a TARGET the TAR- 
GET must maintain an active BSY signal. During DMA oper- 
ations the BSY signal is monitored by th e ASI and will halt 
operations if it goes inactive. To enable BSY to be moni- 
tored at other times the MR2 BSY bit (2) should be set. An 
internjpt will be generated if BSY goes inactive while MR2 
BSY is set. 
This internjpt sets bit 2 in the BSR. 

4.7 COMMAND/MESSAGE/STATUS TRANSFERS 
Command message and stat us bytes ar e transfen-ed using 
programmed-l/O. The SCSI REQ/ACK handshake is ac- 



complished by monitoring and setting lines individually. Data 
is output via the ODR and read in via the CSD register. 
The following code shows INITIATOR and TARGET pro- 
gramming for two of these cases. See Appendix A.I for 
flowcharts. 

Initiator Command Send 

1 

MRS = monitor BSY 
TCR = Command Phase /«02h*/ 
while (bytes) to do) ( 
while (REQ) inactive) 

idle; /*CSB bit 5 = 0*/ 
if (BSR: phase match == 0) 

phase error ; 
else { 

ODR = date byte ; 
ICR = Assert ACiC; 
while (^Q active) 

idle; /*CSB bit 5 == 1*/ 
ICR = deassert ACK 
/* byte transfer complete */ 
byte count — ; 
) 
! 

goto data phase ; 
1 

Target Message Receive 

( 

/* assumed Assert BSY already set in ICR */ 
MR2 = TARG MODE OR PARITY CHECK OR 

PARITY INTERRUPT; 
ICR = Message Out phase ; /*06h*/ 
delay (Bus Settle) ; 
TCR = Assert REQ; 
while (IciC Inactive) 

idle ; /* BSR bit */ 
data = CSD; /* parity is latched */ 
if (BSR: parity error) 

error routine ; 
else f 

TCR = deassert REQ; 

while (ACK active) 
idle; 



O 
"O 
<n 

00 



a 



/* message done, 
phase */ 



can change to next 



4.8 NON-BLOCK DMA TRANSFERS 

Data transfers may be effected by DMA. This method 
should be used for optimum performance. Two methods of 
DMA are available-block and non-block mode. This section 
describes non-block mode transfers. 
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4.0 Device Operation (continued) 

The interface to the DMA controller uses the DRQ, DACK, 
EOP lines i n non-b lock mode. Each byte is requested (DRQ) 
and ack'd (DACK). Representative timing for a DMA read is 
shown in Figure 4.8. 1. 




"V 



y 



>c 



3< 



FIGURE 4.8.1. Non-Block DMA Timing 
4.8.1. NON-BLOCK DIMA 

DMA operation involves programming the ASI with the set- 
up parameters, initiating the DMA cycles and checking for 
correct operation when the completion interrupt is received. 
The DMA controller should be programmed with the data 
byte count and the memory start address. Methods of halt- 
ing a DMA operation are covered in Section 4.1 1 . 
Setting up the ASI requires enabling or dis abling the follow- 
ing: D ata bus driving, DMA mode enable, BSY monitoring, 
EOP interrupt, parity checking, parity interrupt, TARGET 
Mode, bus phase. 

Once set up DMA should be initiated by writing to address 5, 
6, or 7 as appropriate. The DMA controller should assert 
EOP during the transfer of the last byte, although this may 
be done by the iiP if the DMA transfers (n - 1) bytes and 
the ]x.P transfers the last byte. See the application guide for 
more details (Section 7.0). 

Upon completion the jaP should check the following as re- 
quired: End of DMA, Parity Error, Phase Match , Busy Error. 
The end of DMA occurs as a r espon se to EOP. SCSI trans- 
fers may still be underway so REG and ACK must still be 
checked to establish when the final byte is finished. 
The code below shows programming of the ASI in each of 
the four DMA cases. One of these cases is shown in a flow 
diagram In Appendix A. 



Initiator Send 
{ 

Program DMA Controller; 

ICR = OOh; 

ICR = Olh; 

MR2 = OEh; 

SDS = 00; 

while (NOT Interrupt) 
Idle; 

while (CSD:RlQ) 
idle 



/♦DATA OUT PHASE*/ 



/*phase*/ 
/*Assert_DBUS*/ 

/♦Start DMA Send*/ 



/*wait for last 

SCSI byte 
transfer so phase 

is checked*/ 



if (BSRiBusy error OR MOT 
(BSR:End_of_DMA)) 

error routine ; 
else ( /*DMA End*/ 

MRS = 04h; /*reset DMA bit*/ 

ICR = 0; 



Initiator Receive /*DATA IH PHASE*/ 
1 

Program DMA Controller; 

TCR = Olh; /*phase*/ 

MR2 = 3Eh; 

SDI = 0; /*Start DMA Init 

Rx*/ 
while (HOI interrupt) 
idle; 
/*no need to wait for last SCSI handshake 
done since DMA done implies it is 
checked*/ 

if (BSR:parity_error OR HSR: busy.error 
or MOT (BSR End of DMA) 
do error routines ; 
else ( /*End of DMA*/ 

while (CSD:REQ) 
idle ; /*wait for REQ inactive 
to deassert ACK*/ 
MR2 = 04h; 



Target Receive 



/*DATA OUT PHASE*/ 



Program DMA Controller; 

ICR = 0; /*phase*/ 

ICR = 08h; 

MR2 = 7Ah; /*cheok parity*/ 

SDT = 0; /*Start DMA Targ Rx*/ 

while (not interrupt) 

idle; 
/*when End of DMA occurs the last byte 
has been read and checked*/ 
if(feSR:parity_error OR NOT(BSR: End.of.DMA) 
error routine ; 

( else /*End of DMA*/ 
while (BSR:ACK) 
idle; 
/*Not True End of DMA, so wait until SCSI 
bus inactive before changing phase*/ 
MR2 = 40h; 
change phase as required; 
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4.0 Device Operation (continued) 

Target Send /*DAIA IN PHASE*/ 

{ 

Program DMA Controller; 

TCR = Olh; /*phase*/ 

ICE = 09h; 

MR2 = 4Ah; 

SDS = 0; /*Start DMA Send*/ 

while (NOT interrupt) 

idle; 
if(NOT(BSR:End_of_DMA) 

error ; 
else ( /*DMA end*/ 
repeat ( 

while (CSB:REQ OR BSR:AOT) 
loop count = 3 ; 
loop count — ;) /*deorement*/ 
until (loop count == 0) ; 
MR2 = 40h; 
Change phase as required ; 



1 



! 



Some explanation of the final part of Target Send is re- 
quired. In this type of DMA operation it is very difficult to 
exac tly d eterm ine the True End of DMA simply detecting 
REQ and ACK simultaneously inactive is not enough. 
Reference to Figure 4.8.2 ^W help to understand the follow- 
ing text 

Flo 



Byte n-1 



y 



'\ ByUn 
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J \. 



r 
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y 



FIGURE 4.8.2. Target Send DMA 

As shown In Figure 4.fl.^ A CK go ing active caus es the DRQ 
for the next byt e and also REQ to go inactive. ACK going 
inactive allows REQ to go a cBye for the next byte. If the 
INITIATOR is slow rem oving ACK the (tP may sampl e the 
SCS I bus after the EOP interrupt at point A. Here both REQ 
and ACK will be inactive, but there is one more byte to 
transfer on SCSI. Due to chip timing delays this condition 
will not last more than 200 ns. A safe way to de termine the 
True End of DMA is to sample REQ and ACK and ONLY 
when both are Inactive in three successive samples will the 
|xP be at point B in the figure. 



4.9 BLOCK MODE DMA TRANSFERS 

In Bl ock Mode the DMA interface uses the DRQ, DACK, 
EOP and READY lines, DRQ is asserted once at the begin- 
nlngof transfers and deasserted once DACK is received. 
DACK should be asse rted continuously for the duration of 
all the transfer. EOP should be asserted during the last 
DMA byte signal when the next DMA byte transfers. The 
ASI asserts the READY signal when the next DMA byte 
should be transfen'ed. 

As fo r non-block mode the End of DMA interrupt is just 
EOP, also in block mode receiv e the ASI does not return 
READY to an active signal after EOP. This means external 
logic must gate off READY If the jxP is not to be locked up. 
For more details see Section 7.0. 
The block mode is intended for systems where the over- 
head of handing the system busses to and from the jxP and 
DMA controller is too great. The block mode handshake is 
not necessarily faster than non-block (it may be) but the 
overall transfer rate is Improved once the bus exchange 
overhead is removed. Of course the juP is prevented from 
executing for the whole DMA operation. 
If a phase mismatch occurs the READY signal is left in the 
inactive state. The DMA controller must hand back the bus 
to the fiP and the inactive READY signal may need to be 
gated off. 

When performing DMA as an INITIATOR the EOP signal 
does not deass ert AC K on the SCSI bus. Firmware must 
determine when REQ is inactive after the last SCSI transfer 
then reset the MR2 DMA bit to deassert ACK. 
Programming the ASI in block mode Is the same as non- 
block mode except bit 7 in MR2 should also be set. 

4.10 PSEUOO DMA 

The system design can utilize ASI DM A logic for non-data 
transfers. This removes the need to poll REQ/ACK and pro- 
gram the assertlon/deassertion of the handshake signal. 
The jtPcan emulate a DMA controller by asserting DACK 
and EOP signals. DRQ may be sampled by reading the 
BSR. In most cases the chip decode logic can be adapted 
to this use for little or no cost. See Section 7.0 for further 
details. 

4.11 HALTING A DMA OPERATION 

There are three ways to halt a DMA oper ation apart from a 
chip or SCSI reset. These methods are: EOP, phase mis- 
match and resetting the DMA MODE bit in MR2. 

4.11.1 End Of Process 

EOP is as serted for a minimum period during the last DMA 
cycle. The EOP signal generates the End of DMA interrupt. 
EOP does not cause the MR2 DMA mode bit to be reset. 

4.11.2 DMA Phase Mismatch 

If a REQ goes active while there Is a phase mismatch the 
DMA will be halted and an interrupt generated. The ASI will 
stop driving the SCSI bus when the mismatch occurs. A 
phase mismatch is when the TCR phase bits do not match 
the SCSI bus values. 

4.1 1.3 DMA Mode Bit 

If EOP Is not used the best method is to reset the MR2 DMA 
Mode bit. This bit may be reset at any time, and should be 
reset after an End of DMA interrupt or a phase mismatch. 



4-53 



4.0 Device Operation (continued) 

Resetting the bit disables all DMA logic and thus should 
only be reset at the True End of DMA condition. Additionally 
all DMA logic is reset so this bit must be reset then set again 
to carry out the next DMA phase. 

5.0 interrupts 

5.1 OVERVIEW 

Before individually describing each interrupt an explanation 
of the use of interrupts is required. 

5.2 USING INTERRUPTS 

inten-upts are controlled by bits In MR2 if control is provided. 
Not all interrupts can be disabled under software control. 
When an interrupt occurs both the BSR and CSD register 
must be read and analysed to determine the source of inter- 
rupt. Since status is NOT provided for each interrupt great 
care should be exercised when determining the internjpt 
source. 

5.3 SCSI PARITY ERROR 

If SCSI parity checking is enabled via MR2 bit 5 an internjpt 
can occur as a result of a read from CSD, a selection/ 
(re)selection, or a DMA receive operation. The parity error 
bit (bit 5) in the BSR will be set if checking is enabled. An 
interrupt will occur if Enable Parity Interrupt (bit 4) of MR2 is 
set. The inten-upt Is reset by reading HA7. Following an in- 
ternjpt the BSR and CSD should contain the values shown 
below. 



Bit 7 














BItO 





1 


X 


X 


X 


X 





X 



RST BSY RE5 MSG C7D ITS SEL DBP 
CSD 

5.5 DMA PHASE MISMATCH 

When the SCSI REQ goes active during a DMA operation 
the c ontents of t he TCR are compared with the SCSI phase 
lines C/D, MSG and I/O. If the two do not match an inter- 
rupt is generated. This interrupt will occur as long as the 
MR2 DMA bit is set (bit 1), i.e. it cannot be masked. The 
mismatch removes the ASI from driving the SCSI data bus. 
The Inten'upt may reset by reading HA 7. Following an inter- 
rupt the BSR and CSD should contain the values shown 
below. 



Bit? 














BItO 


X 





X 


1 





X 


X 


X 



EDMA DRQ SPER INT PHSM BSY ATN ACK 
BSR 



Bit? 














BItO 





X 


X 


X 


X 


X 





X 



Bit? 














BItO 


X 


X 


1 


1 


X 


X 


X 


X 



EDMA DRQ SPER INT PHSM BSY ATN ACK 
BSR 



RST B5Y Re5 MSG C/D I/O SEL DBP 
CSD 

5.6 BUSY LOSS 

If bit 2 MR2 is set the SCSI 557 signal is monitored and an 
interrupt is generated If BSY is continuously inactive for at 
least a BUS SETTLE DELAY (400 ns). This interrupt may be 
reset by reading HA 7. Following an Interrupt the BSR and 
CSD should contain the values shown below, where usually 
CSD = 00. 



Bit? 














BItO 













1 


X 


X 


X 


X 





X 




Bit? 


BItO 




X 


X 


X 


1 


X 


1 





X 


RST 


BSY 


REQ 


MS(3 c/d 

CSD 


170 


SEL 


DBP 








cr-iMA 


non 


CDCD 


IMT 


DUCKJI 


DOV 


■ATM 


Kr-w 



5.4 END OF DMA 

If EOP is asserted during a DMA transfer bit 7 of the BSR 
will b e set and ah interr upt generate d if bit 3 of MR2 is 1. 
EOP is recognized when EOP, DACK and either IDR or IQW 
are all simultaneously active for a minimum period. The in- 
terrupt may be reset by reading HA 7. Following an inten-upt 
the BSR and CSD should contain the values shown below. 



BSR 



Bit? 














BItO 








X 


X 


X 


X 


X 


X 



Bit? 














BItO 


1 


X 


X 


1 


X 


X 





X 



EDMA DRQ SPER INT PHSM BSY ATN ACK 
BSR 



RST BSY REQ MSG C/D I/O SEL DBP 
CSD 

5.7(RE)SELECTION 

An inten-upt will be generated when: 5EL is active, BSY is 
inactive, and the device ID is true. The device ID Is deter- 
mined by the value in the SER. If ANY non-zero bit in the 
SER has its conrespondlng SCSI data bit active during se- 
lection the device ID is true. If I/O is active this is a reselec- 
tion. The Intenupt is disabled by writing all zeros to the SER, 
and reset by reading HA 7. 
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5.0 Interrupts (continued) 

If SCSI parity checking Is enabled It will be checked and 
should be valid. Following an intermpt the BSR and CSD 
should contain the values shown below. 



Bit? 














BitO 











1 


X 





X 






EDMA DRQ SPER INT PHSM BSY ATN ACK 
BSR 



Bit 7 














BItO 




















1 


X 



R§T BSY REQ MSG C/D 175 SEL DBF 
CSD 

6.0 Reset Conditions 

6.1 GENERAL 



There are three ways to reset the ASJ; jxP chip RESET, 
SCSI bus reset applied externally, SCSI bus reset Issued by 
the ASI. 

6.2 CHIP RESET 

When the RESET signal Is asserted for the required dura- 
tion the ASI clears ALL internal registers and therefore re- 



sets all logic. This action does not create an interrupt or 
generate a SCSI reset. 

6.3 EXTERNAL SCSI RESET 

When a SCSI RST is applied externally the ASI resets all 
registers and logic and issues an interrupt. The only register 
bits not affected are the Assert RST bit (bit 7) In the ICR and 
the TARGET Mode bit (bit 6) in MR2. 

6.4 SCSI RESETISSUED 

When the fiP sets the Assert RST bit in the ICR the RST 
signal goes active. Since the ASI monitors RST also the 
same reset actions as In 6.3 apply. The SCSI RST signal will 
remain active as long a s bit 7 i n the ICR Is set— i.e. until 
programmed or a chip RESET occurs. 

7.0 Application Guide 

This section is intended to show the interface between the 
fiF, ASI and DMA controller (DMAC). Figure 7. 1 shows a 
general interface when the ASI and DMAC are l/O-mapped 
devices. This configuration will Implement a 2 to 2.5M 
Bytes/sec SCSI port using 2 cycle compressed timing from 
the 5 MHz DMAC. 

Using a faster DMAC and memory may allow the ASI to 
operate at a higher rate— but of course any system will be 
limited by the available DMA rate from the SCSI device cur- 
rently connected to. The interface shown has several fea- 
tures that are examined more closely in the following text. 
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FIGURE 7.1. laP/ASI/DMA Interface 
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7.0 Application Guide (continued) 

All the Interface signal requirements are satisfied by a PAL 
device. The memory Interface is not shown, only the rele- 
vant DMAC and ftP lines are Included. 
The ASI data and address lines connect directly to the iiP/ 
DIVIAC busses. The D RQ output from the ASI goes direct to 
the DMAC, The EOP output from the OMAC goes to the ASI 
input, but can also be asserted via the PAL since the DMAC 
output Is open-drain. 

The PAL Is programmed so that the fiP can access the ASI 
in three ways. The thr ee ac cess types are: Register R/W, 
DMA R/W, DMA with EOP. Examination of the PAL equa- 
tions below shows how the juP may perform any of the three 
basic access types simply by accessing the ASI at different 
I/O address slots. This enables the fxP to simulate a DMAC 
(pseudo-DMA). DMA mode may then be used for all Infor- 
mation transfer phases. 



In DMA mode the ASI generates all SCSI handshakes . At all 
other times the jiP is responsible for REQ/ACK hand- 
shakes. Using pseudo-DMA may reduce )u,P overhead. 
When doing DMA transfers via BLOCK MODE and an error 
occurs, the ASI may not deassert the READY signal. For 
some DMA controll ers th is may lock the bus, so the PAL 
asserts READY and EOP to the DMA if an interrupt occurs 
while READY Is false. This completes the current DMA cy- 
cle and prevents further DMA for the rest of the block thus 
allowing the bus to be handed back to the juP for servicing. 
The PAL generates RD and WR strobes while the ^P is bus 
master, but the DMAC provides the strobes while It Is bus 
master so the PAL outputs are TRI-STATE. 
The PAL details are shown in Figure 7.2 with the signal 
definitions and equations following. 



aP 



DMAC 



ASI 



EREAOY 

INT 





NSC PAL 
20L10 
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EOP 

DEOP 

^DMA 
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iOR 

MEMR 

MEMW 



ASI 



DMAC 



FIGURE 7.2. rnterfaee PAL 
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7.0 Application Guide (continued) 



o 

■D 
in 
w 

00 



CSASI = I0RQ*A7*A6*A5*A4*AEN ; 



ADACK = I0RQ*A7*A6*A5*A4*RD ; 

I0RQ*A7*A6*A5*A4*WR 
+I0RQ*A7*A6*A5*A4*RD ; 
+I0RQ*A7*A6*A5*A4*WR 



ASI reg R/W chip select 
fiP pseudo-DMA cycle 

jiP pseudo-DMA with EOF 



+DDACK; ; DMAC DMA cycle 

IF(A1n)AE0P = I0RQ*A7*A6*A5*A4*RD ; jiP pseudo-DMA with EOF 
+1 ORQ* A7*A6 * A5 * A4* WR + DEOP* AREADY 



IF (DDACK*AREADY*INT ) DEOP 



CSDMA = I0RQ*A7*A6*A5*A4 



DREADY = AREADY*INT 



+AREADY*DDACK 
IF(AEN)IOR = IORQ*RD 
IF(AEN)T0W = IORQ*WR 
IF(AEN)MEMR = IDRQ*RD 
IF(AES)MESW = IORQ*M 



DDACK* AREADY* IHI 
;DMA cycle with error 
;DMAC register R/W 
;ASI not READY and not INT 
;ASI not READY and DMA cycle active 
;(u.P I/O Read cycle 
;/u.P I/O Write cycle 
;(xF memory Read cycle 
;jaP memory Write cycle 

FIGURE 7.3. PAL Equations 

The jtP and DMA signals are defined below 



A7-A4 


Address bus 


lORQ 


Memory I/O cycle select 


RD 


■ Read Strobe 


WR 


Write Strobe 


AEN 


High DMA address enable asserted by DMAC 


DDACK 


DMAC DMA Acknowledge 


CSDMA 


DMA Chip Select 


DREADY 


Ready signal to DMAC— inserts wait-states when low 


iOR, low 


I/O data strobes to/from DMAC 


MEMR, MEMW 


Memory data strobe from DMAC 



Q 
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8.0 Absolute Maximum Ratings* 

If Military/Aerospace specified devices are required, 
please contact the National Semiconductor Sales 
Office/Distributors for availability and specifications. 

Supply Voltage (Vcc) - 0.5V to + 7.0V 

DC Input Voltage (Vin) -0.5V to Vcc + 0.5V 

DC Output Voltage (Vqut) -0.5V to Vcc + 0.5V 



Storage Temperature Range (Tstg) - 65''C to + 1 50°C 
Power Dissipation (Pq) 500 mW 

Lead Temperature (TO (Soldering, 1 sec) 260°C 

Electro-Static Discharge Rating 2 i<V 

^Absolute maximum ratings are those values beyond which damage to the 
device may occur. 



9.0 DC Electrical Characteristics (Vcc = s.ov ± 10% unless othenvise specified) ta = o°cto +7o°c 



Symbol 


Parameter 


Conditions 


Typ 


Limit 


Units 


V|H 


Minimum High Level 
Input Voltage 






2.0 


V 


V|L 


Maximum Low Level 
Input Voltage 






0.8 


V 


VOHI 
V0H2 


Minimum High Level 
Output Voltage 


llOUT = 20 iiA 
IIqutI = 4.0 mA 




Vcc - 0.1 
2.4 


V 
V 


V0LI 
V0L2 
V0L3 


Maximum Low Level 
Output Voltage 


SCSI Bus Pins: |IolI = 48 mA 
Other Pins: lloJ = 20 (lA 
IIolI = 8.0 mA 




0.5 
0.1 
0.4 


V 
V 
V 


llN 


Maximum Input Current 


V|N = VccorGND 




±1 


HA 


loz 


Maximum TRl-STATE Output 
Leakage Cun'ent 


VouT = VccorGND 




±10 


fiA 


Ice 


Supply Current 


V|N = VccOrGND 
SCSI Inputs = 3V 


2.5 


4 


mA 



Capacitance ta = 25°c,f = i mhz 



Symbol 


Parameter (Note 3) 


Typ 


Units 


C|N 


Input Capacitance 


5 


PF 


CouT 


Output Capacitance 


7 


PF 



S, (Note 2) 



AC Test Conditions 



Input O 



Input Pulse Level 


GNDtoS.OV 


Input Rise and Fall Times 


6 ns 


Input/Output Reference Levels 


1.3V 


TRl-STATE Reference Levels 
(Note 2) 


Active Low + 0.5V 
Active High - 0.5V 




TL/F/9756-11 



Note 1: Cl = 50 pF Including jig and scope capacitance. 
Note 2: SI = Open for push-pull outputs. 

81 - Vcc tor active low to TRl-STATE. 

SI - GND for active high to TRl-STATE. 
Note 3: This parameter is not 100% tested. 
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10.0 AC EleCtriCdl Characteristics an parameters are preliminary and subject to change without 



notice 



Symbol 


Parameter 


DP5380 


Units 


MIn 


Typ 


Max 


bfas 


BSY False to Arbitrate Start 


1200 




2200 


ns 


bfbc 


BSY False to Bus Clear 






800 


ns 


rst 


RESET Pulse Width 


150 






ns 


stbc 


SEL True to Bus Clear 






500 


ns 



o 

cn 

b» 
00 

o 



10.1 ARBITRATION 



SEL 



BSY 



DB0..7 



BSY 



y 



-bfas- 



10.2 fj.P RESET 



RESET 



\ 






\. 



\. 



f 



-rst- 
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10.0 AC Electrical Characteristics 

all parameters are preliminary and subject to cliange without notice (Continued) 


Symbol 


Parameter 


DP5380 


Units 


Min 


Typ 


Max 


ahr 


Address Hold from End of Read Enable (Note 1) 


10 






ns 


ahw 


Address Hold from End of Write Enable (Note 2) 


10 






ns 


as 


Address Setup to Read or Write Enable (Notes 1 , 2) 


10 






ns 


csli 


CS Hold from End of RD or WR 









ns 


dhr 


Data Hold from End of Read Enable (Notes 1 , 3) 


10 




60 


ns 


dhw 


fiP Data Hold Time from End of WR 


20 






ns 


dsw 


Data Setup to End of Write Enable 


50 






ns 


rdv 


Data Valid from Read Enable (Note 1) 






100 


ns 


WW 


Write Enable Width (Note 2) 


60 






ns 


Note 1: Read enable (/nP) Is CS and RD active. 

Nate 2: Write enable (fiP) Is CS and WR active. 

Note 3: This Includes the RC delay inherent in the tests' method. These signals typically turn off after 25 
contention. 

10.3 piP WRITE 


ns enabling other devices to drive these lines with no 




l< nt >.| 




1, 


-ah 


.1 








1* as »| 


>L 


w -I 






\ 


_y 








r ** 








'' 






WR \ 


p| I 


-dh 


w .1 


















10.4 (iiP READ 


X 

> 








Y 


TL/F/975$-14 






, 1 




-ah 


X_ 

. 1 
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10.0 AC Electrical Characteristics (continued) 

10.5 DMA WRITE (NON-BLOCK MODE) TARGET SEND 

/ v__ 



DRQ 



y 
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Symbol 


Parameter 


DP5380 


Units 


Min 


Typ 


Max 




afrt 


ACK False to REQ True (DACK or WR False) 






120 


ns 


atdt 


ACK True to DRQ True (Target) 






90 


ns 


atrf 


ACK True to REQ False (Target) 






115 


ns 


dfdt 


DACK False to DRQ True 


30 


90 




ns 


dfrt 


DACK False to REQ True (ACK False) 






110 


ns 


dhwr 


DMA Data Hold Time from End of WR 


30 






ns 


dkhw 


DACK Hold from End of WR 









ns 


dsrt 


SCSI Data Setup to REQ True (Target Send) (Note 1) 


40 






ns 


dswd 


Data Setup to End of DMA Write Enable 


50 






ns 


dtdf 


DACK True to DRQ False 






100 


ns 


eop 


Width of EOP Pulse (Note 2) 


40 






ns 


wwn 


DMA Non-Block Mode Write Enable Width (Note 3) 


60 






ns 



Q 



Note 1: EOP, 
Not* 2: Write 



DACK, RD/WR must all be true for recognition of EOP. 
enable (DMA) is DACK and WR active. 
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10.0 AC Electrical Characteristics (continued) 

10.6 DMA WRITE (NON-BLOCK MODE) INITIATOR SEND 
/ 
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Symbol 


Parameter 


DP5380 


Units 


MIn 


Typ 


Max 


dfaf 


DACK False to ACK False (Non-Block Initiator Send) 






120 


ns 


dfdt 


DACK False to DRQ True 


30 


90 




ns 


dhi 


SCSI Data Hold from Write Enable— Initiator 


15 






ns 


dhwr 


DMA Data Hold Time from End of WR 


30 






ns 


dkhw 


DACK Hold from End of WR 









ns 


dswd 


Data Setup to End of DMA Write Enable 


50 






ns 


dtdf 


DACK True to DRQ False 






100 


ns 


eop 


Width of EOP Pulse (Note 1) 


40 






ns 


rfdt 


REQ False to DRQ True 






100 


ns 


rtat 


REQ True to ACK True (Initiator Send) 






100 


ns 


wwn 


DMA Non-Block Mode Write Enable Width (Note 2) 


60 






ns 



Note 1: EOP, DACK, RD/WR must all be true for recognition of EOP. 
Note 2: Write enable (DMA) is DACK and WR active. 
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10.0 AC Electrical Characteristics (continued) 

10.7 DMA READ (NON-BLOCK MODE) TARGET RECEIVE 

/ V 
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Symbol 


Parameter 


DP5380 




Min 


Typ 


Max 




afrt 


ACK False to REQ True (DACK or WR False) 






120 


ns 


atdt 


ACK True to DRQ True (Target) 






90 


ns 


atrf 


ACK True to REQ False (Target) 






115 


ns 


ddv 


DMA Data Valid from Read Enable (Note 1 ) 






90 


ns 


dfdt 


DACK False to DRQ True 


30 


90 




ns 


dfrt 


DACK False to REQ True (ACK False) 






110 


ns 


dtir 


Data Hold from End of Read Enable (Notes 1 , 2) 


10 




60 


ns 


dhra 


SCSI Data Hold from REQ or ACK True (Receive) 


30 






ns 


dkhr 


DACK Hold from End of RD 









ns 


dsra 


SCSI Data Setup Time to REQ or ACK True (Receive) 


20 






ns 


dtdf 


DACK True to DRQ False 






100 


ns 


eop 


Width of EOP Pulse (Note 4) 


40 






ns 



o 

w 
00 



a 



Note 1: Read enable (DMA) Is DACK and RD active. 

Note 2: This includes the RC delay inherent tn the tests' method. These signals typically turn off after 25 ns enabling other devices to drive these lines with no 

contention. 

Note 3: EOP. DACK, RD/WR must all be tme for recognition of EOP. 
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10.0 AC Electrical Characteristics (Continued) 

10.8 DMA READ (NON-BLOCK MODE) INITIATOR RECEIVE 
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Symbol 


Parameter 


DP5380 


llnitA 


MIn 


Typ 


Max 




ddv 


DMA Data Valid from Read Enable (Note 1 ) 






90 


ns 


dfaf 


DACK False to ACK False (REQ False, Non-block, In rx) 






120 


ns 


dfdt 


DACK False to DRQ Tme 


30 


90 




ns 


dhr 


Data Hold from End of Read Enable (Notes 1 , 2) 


10 




60 


ns 


dhra 


SCSI Data Hold from REQ or ACK True (Receive) 


30 






ns 


dkhr 


DACK Hold from End of RD 









ns 


dsra 


SCSI Data Setup Time to REQ or ACK True (Receive) 


20 






ns 


dtdf 


DACK True to DRQ False 






100 


ns 


eop 


Width of EOP Pulse (Note 3) 


40 






ns 


rfaf 


REQ False to ACK False (DACK False) 






100 


ns 


rfat 


REQ True to ACK True (Initiator Receive) 






100 


ns 


rtdt 


REQ True to DRQ True 






120 


ns 



Note 1: Read enable (DMA) is DACK and RD active. 

Not* 2: This includes the RC delay Inherent in the tests' method. These signals typically turn off after 25 ns enabling other devices to drive these lines with no 
contention. 

Note 3: EOP, DACK, RD/WR inust all be tme for recognition of EOP. 
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10.0 AC Electrical Characteristics (continued) 

10.9 DMA WRITE (BLOCK MODE) TARGET SEND 
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Symbol 


Parameter 


DPS380 


Units 


Min 


Typ 


Max 




afrt 


ACK False to REQ True (DACK or WR False) 






120 


ns 


atrf 


ACK True to REQ False (Target) 






115 


ns 


atrt 


ACK True to READY True (Block Mode Target Send) 






110 


ns 


dhat 


SCSI Data Hold from ACK True 


40 






ns 


dhwr 


DMA Data Hold Time from End of WR 


30 






ns 


dsrt 


SCSI Data Setup to REQ True 


50 






ns 


dswd 


Data Setup to End of DMA Write Enable 


50 






ns 


dtdf 


DACK True to DRQ False 






100 


ns 


eop 


Width of EOP Pulse (Note 1) 


40 






ns 


rtwf 


READY true to WR False 


60 






ns 


wfrf 


WR False to READY False 






100 


ns 


wfrt 


WR False to REQ True (ACK False) 






120 


ns 


wwb 


DMA Write Enable Width (Note 2) 


60 






ns 



o 

•TJ 
Ol 

w 
00 

o 



Note 1: EOP, 
Note 2: Write 



DACK, RD, WR must all be tiue for recognition of EOP. 
enable (DMA) Is DACK and WR active. 
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10.0 AC Electrical Characteristics (continued) 

10.10 DMA WRITE (BLOCK MODE) INITIATOR SEND 
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Symbol 


Parameter 


DP5380 


Units 


Min 


Typ 


Max 


dhi 


SCSI Data Hold from Write Enable— Initiator 


15 






ns 


dhwr 


DMA Data Hold Time from End of WR 


30 






ns 


dswd 


Data Setup to End of DMA Write Enable 


50 






ns 


dtdf 


DACK True to DRQ False 






100 


ns 


eop 


Width of EOP Pulse (Note 2) 


40 






ns 


rfyt 


REQ False to READY True 






80 


ns 


rtat 


REQ True to ACK True 






100 


ns 


rtwf 


READY True to WR False 


60 






ns 


wfaf 


WR False to ACK False (REQ False) 






120 


ns 


wfrf 


WR False to READY False 






100 


ns 


wwb 


DMA Write Enable Width (Note 1) 


60 






ns 



Note 1: Write enable (DMA) is DACK and WR active. 

Note 2: EOP, DACK, RD/WR must all be true for recognition of EOP. 
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10.0 AC 1 

10.11 DMA RE 
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Electrical Characteristics (continued) 

.AD (BLOCK MODE) TARGET RECEIVE 
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Symbol 


Parameter 


DP5380 


Units 


Min 


Typ 


Max 


afrt 


ACK False to REQ True (DACK or WR False) 






120 


ns 


atrf 


ACK True to REQ False 






115 


ns 


atyt 


ACK True to READY True 






110 


ns 


ddv 


DMA Data Valid from Read Enable (Note 1) 






90 


ns 


dhr 


Data Hold from End of Read Enable (Notes 1 , 2) 


10 




60 


ns 


dhra 


SCSI Data Hold from REQ or ACK True 


30 






ns 


dsra 


SCSI Data Setup Time to REQ or ACK True 


20 






ns 


dtdf 


DACK True to DRQ False 






100 


ns 


eop 


Width of EOP Pulse (Note 3) 


40 






ns 


rfrt 


RD False to REQ True (ACK False) 






100 


ns 


rfyf 


RD False to READY False 






110 


ns 


rydv 


READY True to Data Valid 






35 


ns 


Note 1: Read enat 
Note 2: This Includ 
contention. 
Note 3: EOP, DAC 


le (DMA) is DACK and RD active. 

es the RC deiay inherent in the tests' method. These signals typically tu 

K, RD/WR must all be active for recognition of EOP. 


m off after 25 ns 


enabling other d« 


ivices to drive these tines with no 
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10.0 AC Electrical Characteristics (continued) 

10.12 DMA READ (BLOCK MODE) INITIATOR RECEIVE 
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Symbol 


Parameter 


DP5380 


Units 


MIn 


Typ 


Max 


ddv 


DMA Data Valid from Read Enable (Note 1 ) 






90 


ns 


dhr 


Data Hold from End of Read Enable (Notes 1, 2) 


10 




60 


ns 


dhra 


SCSI Data Hold from REQ or ACK True 


30 






ns 


dsra 


SCSI Data Setup Time to REQ or ACK True 


20 






ns 


dtdl 


DACK True to DRQ False 






100 


ns 


eop 


Width of EOP Pulse (Note 3) 


40 






ns 


rdaf 


RD False to ACK False (REQ False) 






125 


ns 


rfaf 


REQ False to ACK False (DACK False) 






100 


ns 


rfyf 


RD False to READY True False 






110 


ns 


rtatZ 


REQ True to ACK True 






100 


ns 


rtyt 


REQ True to READY True 






75 


ns 


rydv 


READY True to Data Valid 






35 


ns 



Note 1: Read enable (DMA) Is DACK and RD active. 

Note 2: This includes the RC delay Inherent in the tests' method. These signals typically turn off after 25 ns enabling other devices to drive these lines with no 

contention. 

Note 3: EOP, DACK, RD/WR must all be active for recognition of EOP. 
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Appendix A1 
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*Only set ATN if Seiect with ATN is desired. 



Appendix A1 (continued) 

Command Transfer (Initiator) 
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Appendix A2 



Register Chart 
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National Semiconductor's new SCSI Interface devices 
raise the standard of low cost SCSI. 

National Semiconductor has two new low cost, high per- 
formance Small Computer Systems Interface (SCSI) devic- 
es; the DP538P and DP8490. The DP5380 Asynchronous 
SCSI Interface (ASI) is pin and program compatible with the 
NMOS NCR5380 type device, but since it is manufactured In 
CMOS it offers speed and power advantages. The DP8490 
Enhanced Asynchronous SCSI interface (EASI) is pin com- 
patible with the ASI, and program compatible until its en- 
hanced mode Is set. This mode offers features and architec- 
tural improvements which can greatly Increase a system's 
throughput. IHowever a major factor in favor of both devices 
is the improvement in their achievable data transfer rate. 
Users who have replaced their fJMOS 5380 type devices for 
National devices, In an existing application, have found im- 
provements of between 10 and 15 percent in data transfer 
speeds. That is with no other changes to their application. 
For new designs, or performance upgrades, the gains possi- 
ble can be much more dramatic. 

in many applications the limiting factor in a data transfer is 
the DMA controller. This presented a problem to users i.e., 
"How fast can the National devices transfer data?" To de- 
termine this National designed an asynchronous DMA con- 
troller, using a programmable gate array, which can go as 
quicldy as the SCSI device will allow it. In these tests the 
National devices were up to 140% faster than the 
NCR5380 equivalent. 

SYSTEM OVERVIEW 

A general SCSI application is shown in Fyure 1. This shows 
the hardware required to interface a SCSI bus to a peripher- 



al controller, without the devices to control the peripheral 
itself. The Central Processing Unit (CPU), the only "intelli- 
gent" disvice, controls all operations. It communicates with 
the SCSI bus through the EASI or ASI, which both support 
selection, reselection, arbitration and all other bus phases 
detailed in the ANS X3.131-1986 SCSI standard defined by 
the ANSI X3T9.2 committee. Since these devices can act as 
both target and initiator this could be the core of a peripher- 
al controller or a host adaptor. 

For optimum performance a DMA controller is used to trans- 
fer data between the SCSI device and memory. This memo- 
ry is used as a cache for the final destination, which could 
t>e main system memory, a hard disk, floppy disk, printer, 
etc. By adding the appropriate Interface the core shown in 
Figure 1 can be adapted for the particular application. 

TEST SYSTEM 

To fully test the achievable DMA rate National built two 
boards of the form shown in Figure 1. The first board config- 
ures itself as an initiator, the second acts as a target. The 
initiator arbitrates for the SCSI bus, until successful, then 
selects the target and sends a Write command. This causes 
a DMA transfer from the initiator to the target. 
The initiator arbitrates for the bus again, selects the target 
and sends a Read command. The data sent to the target is 
returned to the initiator, under DMA control, and checked. 
This process is constantly repeated, with the transmitted 
data varying between "01,FF,00,01 etc." and "FF,01,00,FF 
etc." This checks every data bit and varies the parity bit. 
The two boards continually transmit blocks of data, alternat- 
ing between Initiator Send/Target Receive and initiator Re- 
ceive/Target Send modes. 



Date Bus 




FIGURE 1. Core of a SCSI Controller 
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TEST CIRCUIT 

The two boards have identical circuitry, shown in Figure 2. 
The CPU is an NSCBOOtm 8-bit CH/IOS microprocessor, 
which requires an octai iatch to demultiplex the address and 
data bus. The boards configuration, initiator or target, de- 
pends on the system software stored in the EPROM. Fast 
static RAM is required for the cache, CIVIOS RAM with an 
access time of 45 ns was selected. A PAL® Is used to de- 
code the chip selects. The SCSI controller can be either a 
5380 or a DP8490. 

The DMA controller was implemented in a Xilinx Program- 
mable Gate Array. These devices offer a quicic, easily adapt- 
able method of prototyping. The design is entered as a 
schematic, then converted to the gate anray format by a 
software package. Routing is largely automatic, but complex 
designs require a certain amount of interaction. In a speed 
critical design, such as the DMA controller, manual control 
of routing delays is vital. 

The Xilinx device can automatically load its configuration 
from an EPROM on power-up. This could be the same 
EPROM that contains the boards software, but for simplicity 
during prototyping a separate device was used. 



A 



Software 
EPROM 
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DMA DESIGN 

The DMA controller required was highly application specific 
and could therefore be relatively simple. It basically consists 
of a counter, a register and control logic (Figure 3). The 
counter is loaded with the start address of the DMA block 
and the register with the end address. On a subsequent 
DMA request the controller has to take control of the micro- 
processor bus and transfer data until the address in the 
counter equals the address in the end register. 
The DMA is enabled by setting a bit in the control register. 
The other control bit determines whether the transfer is a 
memory read or a memory write. 

Once enabled, a subsequent DMA requ est (ORG) will cause 
the device to issue a bus request (BRQ). When it receives a 
bus acknowledge (BACK) from the processor it asserts the 
counter out put ont o the address bus and Issues a DMA ac- 
knowledge (DACK). The DMA controller also takes control 
of the I/O and memory read an d write strobes. This device 
only operates in block mode, so DACK is asserted through- 
out th e transfer. The SCSI device deasserts DRQ when 
DACK goes active. This is used to start the first transfer. 
Subsequent transfers are triggered by the throttle control, 
READY, going high. 
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For a m emor y read, RD is held active throughout t he tr ans- 
fer and lOW is strobed. For a memory write, both iSR and 
WR are strobed. The basis of the control logic is shown in 
Figure 4. 

Figure S shows the timings of the circuit in Figure 4. The I/O 
or memory strobe pulses low for the time difference tie- 
tween READY going high and the STROBEIN input causing 
CLOCK to go high. Thus the external delay line controls the 
strobe signals pulse widths. The bacl< edge of CLOCK is 
used to Increment the address counter. 



The controller continues as in Figure 5, until the EOP (End 
of Process) signal is asserted. This is either asserted exter- 
nally, to prematurely end a transfer, or by the DMA control- 
ler itself, once the cun'ent address counter equals the end 
address register. . 

The speed that the DMA controller transfers data is deter- 
mined by the R EADY line. The SCSI controller deasserts 
READY after an lOW or ISR, then asserts it when It Is ready 
to transfer the next byte. This high transition triggers the 
next transf er of t he D MA controller. Varying delay line time 
varies the lOR, lOW and WR pulse widths, so different 
speeds of devices can be accommodated by this controller. 

AO A1 A2 CS (chip select) 



I End Addfas ReglstT Q 



Lood Low Byte 



Comparator 



I 



Load High Byte 
Equol Addresses 



IT^T' 



Current Address Counter 



TF 



16 Btt Address Bus 



Lood Low Byte 



Load High Byte 



Counter Increment 



11 1 1 



2 Control Bits 

Control Logic 



8 BH Data Bus 



TTTT 



' DMA request 

■ DMA acknowledge 

• Bus request 

• Bus acknowledge 

• READY (throttle 
control from SCSI) 

^ End of Process 
(output to SCSI 
or Input from 
elsewhere) 



RD low WR lOR 
FIGURE 3. Block Diagram of DMA Controller 



READ/WRiTE Control Bit 



READY 1^" 
DRQ 



kSTROBEOUT k,^ STROBEIN 
External Dekiy Line 



;^ 



RESET 




CLOCK 



fO 



=o 




BACK f £ _• 




{y-^ 



RD 



FIGURE 4. DMA Control Logic 



4-74 



DRQ 



BRQ 



BACK 



MCK 



SCSI device SCSI devjcejleasserts DRQ 
Issues DRQ when DACK goes active 



DMA controller responds to DRQ 
by requesting processor bus 



■^ 



processor finishes current machine 
cycle and passes over bus control 



DMA controller asserts DACK when 
It takes control of proeaaor bus 



"°1gl////////X 



X 



K>Rft 



Bus tri-state In time between processor 
releasing bus and DMA taking control 



CLOCK Increments 
counter 



^^unznnh^ 



Unknown 



(for memory read) Unknown 



follows CLOCK Stays high despfte CLOCK Goes low when 
being low because READY Is low READY goes 
high 



Ul 
tfl 



READY 



STROBEOUT 



STROBEIN 



1 



J 



Goes k)w when 
DRQ goes high 



DRQ goes low 



Delay Una 
Delay line I T 



Goes low after lOR 
or low goes high 



Goes low when 
READY goes low 



Returns high once SCSI 
bus handshake complete 



RESET 



CLOCK 



J 



1 



Goes high when 
DRQ goes high 



Reset 



Goes high when 
READY goes low 



STROBEIN ckxks 
through a high 



Reset 



r 



FIGURE 5. DMA Controller Timings 



4-75 



BENCHMARKING 

The system used for the benchmarking is shown in Figure 6. 
The two boards were connected by three different lengths 
of cable; 50 cm, 3m and 6m (the maximum length of single 
ended cable allowed). 50-way STD IDC ribbon cable was 
used, wired as per SCSI specification with every second line 
grounded. All SCSI signal lines were terminated on both 
boards, with a 330n resistor to ground and a 220(1 resistor 
to Vcc- 

A Hewlett Packard 16500A Logic Analysis system was used 
to monitor the control signals and measure the burst DMA 
rate. The 10 ns sampling rate gave sufficient accuracy to 
measure handshaking speeds which were all below 
5 Mbytes/s. 

The first byte of a transfer is delayed, as the initiator takes 
time to follow the phase set by the target. After this the 
DMA controller reaches Its peak transfer rate, which is 
maintained until the end of the transfer. The frequency of 
the SCSI bus handshaking signal, REQ, was measured, to 
give the data transfer rate. 

BENCHMARKED DEVICES 

Initially It was planned to benchmark three manufacturers 
devices, that is National Semiconductor, NCR and Logic 
Devices. 

Different Lengths of SCSI Bus 



However it was found that the Logic Devices part caused 
problems in the test board and would not function in con- 
junction with any other manufacturers device. The DMA 
controller uses DRQ to generate the first read and write 
strobes (see DMA Design section), but expects the signal to 
stay inactive for the rest of the transfer. The Logic Devices 
5380 produces a spurious DRQ during a block mode trans- 
fer. This corrupts the read and write strobes produced by 
the DMA controller. The Logic Devices 5380 would not in- 
terface to other manufacturers devices because of its parity 
checking method. National and NCR only check the bus 
parity as they load their input data register. Logic Devices 
check parity when ACK is active, for Target Receive or 
when REQ is active for Initiator Receive. However, the Na- 
tional an d NCR devices write the next byte of data before 
the REQ/ ACK handshake for the previous byte is complete. 
As parity is decoded through logic the data will be on the 
bus before the parity bit is valid. Logic Devices detect this as 
a parity error, which causes the transfer to be terminated. 
The National and NCR devices were fully interchangeable. 
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BENCHMARK RESULTS 

The transfer rate during a data phase was measured for a 
sample of National and NCR devices, over three lengths of 
cable. Measurements were made for initiator Send/Target 
Receive mode and for initiator Receive/Target Send mode. 
When a NCR device was used the delay line time was In- 
creased, to allow for Its slower reading and writing times. 
Figures 7a, b and c show the results. 
These tables show the dramatic speed advantages of the 
National device over NCR. The National device maintains a 
significant advantage over all three lengths of cable. It may 
appear that the NCR device maintains its speed better over 
longer lengths of cable, but only because the added propa- 
gation delays of the cable are a smaller percentage of the 
transfer time. 



The Initiator Receive/Target Send mode is Inherently faster, 
which makes the specification of one DMA rate for the de- 
vice a highly debatable subject, even If the length of cable 
for the measurement is agreed. However, customers using 
the SCSI device for a disk application will appreciate the 
fact that this mode Is faster, since approximately 80% of 
disk accesses are reads, while running most software. 
Even if only one National device is used there is a signifi- 
cant improvement in performance, but to fully realize the 
potential of the SCSI interface two National devices are re- 
quired. Figure 8 shows just how much of an improvement 
this is. 
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CONCLUSiONS 

The new asynchronous SCSI interface devices from Nation- 
al offer an instant improvement to old designs. By changing 
over to National devices the user can upgrade an existing 
SCSI interface by upwards of 10%, with no further effort. 
For greater performance improvements a fast DMA control- 
ler Is required, at which point the asynchronous SCSI ap- 
proaches synchronous SCSI speeds. 
For new designs the DP8490 EASI is the ideal choice. In 
addition to the fast DMA transfer rate, this device offers 
architectural improvements which can greatly boost a sys- 
tems throughput. In a 5380 the arbitration time is dead to 



the system, as the device must be polled to determine when 
this phase has started. By interrupt driving arbitration the 
DP8490 EASI frees many milliseconds, or even seconds, to 
be used at the system designers discretion. This time may 
be utilized for disk cacheing, overlapped seeks, printing etc. 
depending on the particular application. The entire Intermpt 
structure has been revamped, making software for this de- 
vice quicker to develop and quicker to run. To further ease 
software overheads the troublesome bugs of the 5380 have 
been fixed. 

By improving the speed of data transfers, lowering the pow- 
er consumption and offering new additions to a familiar 
SCSI interface device, National have rejuvenated asynchro- 
nous SCSI. 
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DP8490: E.A.S.I. Does It! 



National's Enhanced Asynchronous SCSI Interface (EASI) 
offers features that can yield Increases in system perform- 
ance over designs incorporating a 5380 type device. 
When looking for a low cost Small Computer Systems inter- 
face (SCSI) controller many users adopt the 5380 Asyn- 
chronous SCSI Interface (ASI) despite its many document- 
ed flaws and undocumented difficulties in operation, familiar 
to any past user. This device tended to be selected due to 
the lack of an alternative, but the DP8490 EASI from Nation- 
al Semiconductor will change this. The EASI is pin compati- 
ble with the ASI, and software compatible until an enhanced 
mode bit is set. This enhanced mode offers features which 
can increase the performance of a system currently using a 
5380 type device. This is achieved through improvements to 
speed and architecture, while eliminating the 5380's inher- 
ent bugs. 

SYSTEM OVERVIEW 

The DP8490 and DP5380 support selection, reselection ar- 
bitration and all other bus phases as detailed in the ANS 
X3.131-1986 SCSI standard defined by the ANSI X3T9.2 
committee. As the devices can act as both TARGET and 
INITIATOR they are suitable for any SCSI bus application. A 
typical application will look like Figure 1. 

The C.P.U. controls all operations by reading and writing 
registers in the I/O devices; to achieve a high performance 
a member of the HPC16000 microcontroller family can be 
used. For optimum performance a DMA controller handles 
data transfers between the EASI and memory. The memory 
is used as a data cache for the final destination, which may 
be a hard disk, RAM disk, printer etc. f^igure 1 shows the 
basic system but not the hardware required to interface to 
such a peripheral. The EASI has high-current open-drain 
drivers which Interface directly to the SCSI bus. 

SPEED AND POWER IMPROVEMENTS 

National's DP8490, and DP5380, are implemented in low 
voltage silicon gate microCMOS, which gives power and 
speed improvements over existing NMOS 5380 parts. The 
National devices have a maximum supply current of 4 mA, 
compared to the NCR5380 145 mA, and DMA rates of over 
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3 Mbytes/second, compared to 1.5 Mbytes/second. Nation- 
al's EASI device has rediioed timing parameters; read ac- 
cess times are reduced from 130 ns to 50 ns, write data 
hold times, from 30 ns to 10 ns and all other parameters 
correspondingly improved. 

ENHANCED INTERRUPTS 

The DP8490 enhanced mode intemjpt structure is consider- 
ably different to that of the 5380. The source of Interrupt is 
available by reading one register, the Interrupt Status Regis- 
ter (ISR). In order to find the source of internipt in the 5380 
two registers must be read. In addition all interrupts are 
flagged in enhanced mode. With the 5380 a selection inter- 
rupt has to be determined by the absence of other flags 
while the select line is active. Since selection is the means 
of establishing contact with other devices on the SCSI bus it 
is a common occurrence. The DP8490 supplies an inten-upt 
flag for this and all other intemjpts. This enhanced interrupt 
stmcture should simplify system software, thus increasing 
the speed of interrupt servicing. Simplified code is easier to 
understand, and therefore easier to adapt or repair. 
All internjpts are maskable, using the Inten-upt Mask Regis- 
ter (IMR), but interrupts cannot be lost since resetting the 
Interrupts only resets those bits that were active on the last 
read of the ISR. This achieves a greater error tolerance. 

INTERRUPT DRIVEN ARBITRATION 

An enhancement which will have a great effect on many 
system's performance is the addition of an arbitration inter- 
rupt. In the 5380, arbitration is polled. On a busy SCSI bus, 
arbitration will take typically many milliseconds, and poten- 
tially many seconds. Therefore, time which could have been 
spent doing overlapped seeks, or filling a data buffer is in- 
stead used reading a 5380 register waiting for a flag to go 
active. The enhanced mode of the DP8490 offers interrupt 
driven arbitration, allowing the user to utilize this time in data 
cacheing, data manipulation, etc., thus increasing the sys- 
tem throughput. This increase in system performance can 
become particularly effective in low priority devices which 
will typically have to arbitrate for the bus the longest. 
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INCREASED TESTABILITY 

The enhanced mode is set using a register bit which, in the 
5380 initiates the Test Mode'. In Test Mode all output driv- 
em on the device are disabled, so although the device can 
still be written, no data can be read. This makes it unsuitable 
for any application. In addition, DMA and intenrupt requests 
are tri-stated, which may cause system problems, 
in contrast, the enhanced mode of the DPe4go offers a 
loopback facility, where the SCSI drivers are disabled, and 
the SCSI l/O's loop back inside the EASI. This loopback 
test mode allows all device signals to be fully tested, includ- 
ing a DMA transfer. Using this, a system can perform a full 
self diagnostic test, without affecting the SCSI bus. Good 
diagnostic testing simplifies system error detection and 
checking. 

TRUE END OF DMA DETECTION 

Another Interrupt improvement In the enhanced mode Is 
seen during DMA operation. The 5380 will generate an end 
of DMA interrupt when it sees a concurrent EOP, DACK and 
lOR or iOW, even though the SCSI bus transfer may not be 
complete. To overcome this the user must examine REQ 
and ACK, to determine a true end of transfer. Consider Fig- 
ured 
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If an Initiator Is slow in removing the ACK, the processor 
could sample REQ and ACK after the EOP interrupt, at point 
A. At this point REQ and ACK are both Inactive, although 
there Is still one byte to transfer. The user must see REQ 
and ACK inactive on three successive transfers to be confi- 
dent the transfer is complete (point B). Thus a great deal of 
time Is wasted ensuring the last byte of every DMA transfer 
Is successful. The EASI eliminates this inefficiency by de- 
tecting, and inteniiptlng on, true end of DMA, when ACK 
goes Inactive. 

TIMING ENHANCEMENTS 

Some of the major bugs In the 5380 are experienced in 
DMA mode. In Initiator receive mode. If a REQ is received, 
after a valid EOP, an ACK will be generated although no 
valid data exists. This could be a particular problem for us- 
ers who have to split a block transfer Into two, perhaps to 
prevent crossing a page boundary. Part of the second block 
of data could be lost by the generation of these spurious 
ACK's. Another problem experienced by an Initiator In DMA 
mode is ACK being left asserted after receipt of a valid EOP. 
After receiving the end of DMA interrupt the processor must 
'manually' deassert ACK by writing to the relevant register. 
These problems make the DMA mode In a 5380 extremely 
difficult to use. Extra software is required to ensure correct 
operation, making boards incorporating a 5380 run slower. 
None of these problems exist in the enhanced mode of 
the DP8490. 

BUS TERMINATION 

The most common SCSI bus Is a 50 way ribbon cable, of up 
to six meters long, with SCSI devices daisy chained along it. 
The devices at either end of the bus should terminate ail 
SCSI lines with a 330n resistor to ground and a 220n to 
power. To ensure the bus can operate correctly, even if the 
device at one end Is not powered up, the power to these 
terminators can be made available on the SCSI bus. This 
allows the tennlnators to always receive power. The bus 
configuration is shown in Figure 3. Terminator power is fed 
through a Schottky diode to prevent a backflow of power 
Into either of the devices. 
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Some manufacturers' CMOS devices will not work in this 
configuration, since when not receiving power they pull the 
SCSI line low. Therefore all devices on the bus must be 
powered up. Both National's DP5380 and DP8490 have a 
special input protection which mal<es this configuration ac- 
ceptable. 

EXTENDED FEATURES 

The DP5380 and DP8490 are available in a standard 40 pin 
DIP, or in a 44 pin PLCC, which is pin compatible with exist- 
ing 5380 PLCCs. The DP8490 PLCC has a microprocessor 
parity pin. In the enhanced mode, microprocessor bus parity 
checking can be enabled, with parity polarity optional. Since 
parity checking is optional, the PLCC DP8490 can still be 
used In a system wliere the microprocessor does not sup- 
port parity. However, use of this feature will help the confir- 
mation of data validity throughout the system. 
Enhanced mode (for both types of packaging) offers other 
features, including programmable SCSI parity polarity. Al- 
though the specified SCSI polarity is ODD, by enabling 
EVEN parity bus diagnostics can be carried out. In this way 
the error detection and error handling capabilities of other 
devices on the bus can be determined. 



The enhanced mode also has a general phase mismatch 
interrupt. The 5380 only checks phase mismatch during 
DMA. This means that an initiator following the phase set by 
a target must poll the device to determine when it changes. 
Only a change during DMA produces an interrupt. In the 
enhanced mode, an option available gives an interrupt on 
any phase mismatch. This allows for quicker detection of a 
change of phase, thus decreasing the dead time on the 
SCSI bus. 

The wide range of new features available in the DP8490 
makes this part a first choice In any new SCSI designs, or 
upgrades requiring increased performance. For users not 
wishing to make the software changes, required to utilize 
the enhanced features of the DP8490, the DP5380 is avail- 
able, offering speed and power improvements over existing 
parts, at a highly competitive cost. Every user that has tried 
replacing existing NMOS 5380s with either the DP5380 or 
DP8490, at both ends of their existing application, have ex- 
perienced data transfer speed improvements of between 
10% and 15%. That is with no other changes! 
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A SCSI Printer Controller 
Using Either the 
DP8490 EASI or 
DP5380ASIand 
Users Guide 
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The DP8490 Enhanced Asynciironous SCSI Interface and 
DP5380 Asynchronous SCSI Interface are CMOS devices, 
which offer a iow cost high performance Small Computer 
Systems Interface. These devices are pin compatible, and 
software compatible until an enhanced mode bit Is set In the 
DP8490. This enhanced mode offers many new features 
which can yield Increases in system performance through 
software, In addition to the improvements In speed and 
power shown by both devices over existing NMOS devices. 
This application note shows how the hardware and software 
can be designed for a SCSI Printer Controller (SPC) so that 
It can incorporate either the DP5380 or DP8490. Since the 
software automatically detects which device is Inserted ei- 
ther can be used, although the enhanced mode of the 
DP8490 offers a better system In terms of throughput and 
error tolerance. All of the software discussed Is available on 
a floppy disk. 



1.0 Introduction 

The SCSI Printer Controller (Figure 1.1) consists of five 
main parts: 

1. Microprocessor NSC800tm 

2. Printer Interface NSC831 PIO (Parallel Input/Output) 

3. SCSI Interface DP8490 or DPS380 

4. Memory 

CMOS EPROM NMC27C256 
CMOS Static RAM 62256 

5. DMA Controller 9517 or 8237 

The NSC800 Is an eight bit CMOS microprocessor which Is 
the central processing unit of the National Semiconductor 
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1.0 Introduction (continued) 

NSC800 microcomputer family. It is capable of addressing 
64 kbytes of memory and 256 I/O devices using a multi- 
plexed address and data bus. The instnjction set is fully 
compatible with that of the Z80. 

The NSC831 is the parallel Input/output (PIO) device of the 
NSC800 family. This provides 20 I/O bits which can be indi- 
vidually programmed to be inputs or outputs. These are con- 
figured as two eight bit ports and one four bit port. The PIO 
is used as the interface between the microprocessor and 
the printer. 

The DP5380 and DP8490 comply with the ANS X3.131- 
1986 SCSI standard as defined by the ANSI X3T9.2 commit- 
tee. They can act as both Initiator and Target supporting all 
bus phases. Due to the on-chip high-cun'ent open-drain driv- 
ers the devices interface directly to the SCSI bus. 
The 64 kbyte memory space is split between a 32 kbyte 
EPROM, containing the njn-time software, and a 32 kbyte 
static RAM. 

Data transfers between memory and the EASI can be con- 
trolled by the DMA controller, which supplies all read and 
write strobes for a transfer in either direction. This is a syn- 
chronous device which uses the 4 MHz clock output from 
the microprocessor. 

The microprocessor is normally in control of the internal 
busses, giving it the ability to read or write memory or I/O 
devices. During a DMA transfer the DMA takes control of 
these busses and can pass data between the EASI and 
memory. As the microprocessor is the only device with 'in- 
telligence' it must control these transfers. It commences 
and controls operations by setting registers in the DMA and 
EASI. 

2.0 Hardware 

2.1 DEVICES 

2.1.1 Introduction 

This section is intended to explain the hardware of the SPG 
referring to the circuit diagram given in Appendix A. This will 
describe the devices used and the signals generated but 
not the way in which they are programmed. What will be 
discussed is how the devices relate to each other, their rela- 
tive timings, and any extra hardware required. A more exact 
description of the internal registers of the EASI, DMA and 
PIO, and their operation, will be given in the diagnostics 
section. 

2.1.2 Microprocessor 

The NSC800 is an eight bit microprocessor which multiplex- 
es the eight bit data bus with the lower half of the address 
bus to create a sixteen bit address bus. An octal latch, 
MM74HCT373, is required to hold the address on the bus 
during a memory read or write, with the ALE (Address Latch 
Enable) output from the NSC800 strobing the latch. 
Since the bus has devices which use bot h TT L and CMOS 
levels pull-up resistors are required. The lOM output signi- 
fies whether the processor is on a memory or an I/O cycle 
and is used along with the RD and WR outputs to strobe bus 
data. 

This processor allows control of the bus to be passe d to an 
I/O device, using the BRQ (bus request) Input and BACK 
(bus acknowledge) output. On this board the DMA is the 
only device which may request control of the bus. 



When the EASI issues a DMA request the D MA signals that 
it needs control of the bus by is suing a BRQ. The processor 
acknowledges this by issuing BACK, and then drives the 
bus and all related control signals to their high impedance 
state. The MM74HCT373 must TRI-STATE® its outputs; the 
output enable is driven by the DMA signal AEN (address 
enable), which it asserts when it has control of the bus. At 
the end of its operations the D MA re leases AEN (enabling 
the la tch ou tputs) and negates BRQ. The processor de-as- 
serts BACK and retakes control of the bus by enabling its 
outputs. To prevent spurious signals being generated when 
the bus is not driven the control signals must have pull-up 
resistors. 

The N SC800 provides five hardware internjp ts of w hich only 
RSTA is used. The others are tied inactive. RSTA is driven 
by the EASI interrupt output, with an inversion between 
them to allow for the difference in active levels. An interrupt 
on this pin causes a software reset to a particular address in 
memory (more details of interrupt servicing will be given in 
the diagnostic software section). 

The system clock is generated using an 8 MHz crystal, with 
the frequency divided by two for use by the processor and 
the DMA. There is also power-on reset circuitry, which re- 
sets the processor, and causes a reset output to the other 
devices when power is first applied. 

2.1.3 DMA Controller 

The 9517 and 8237 are compatible direct memory access 
devices, controlled by setting internal registers. These regis- 
ters are selected using a chip select, with the particular reg- 
ister selected byjhe lower nibble of the address bus, and 
data strobed by lOR (I/O read) or lOW (I/O write). These 
registers control the type of data transfer, the number of 
bytes transferred and the memory address the transfer is 
to/from. 

The two modes of transfer used are single mode and block 
mode. In single mode the DRQ (DMA request) input and the 
DACK (DMA acknowledge) output are used to "handshake" 
every byte o f data transferred. In block mode, after an initial 
DRQ, DACK must be active until after the last byte has been 
transferred. The rate of transfer is controlled by the READY 
input. 

Another device required in conjunction with the DMA is an 
MM74HCT74 'D' type flip-flop. This is used to overcome the 
metastability problem introduced by the asynchronous 
READY signal driving a synchronous device. The flip-flop 
synchronizes the input with the system clock. 
The DMA supplies all the necessary control signals to move 
data from memory to EASI or vic e-vers a. When all data has 
bee n tran sferred the DMA drives EOP (end of process) ac- 
tive. EOP can also be used as an input to the DMA, prema- 
turely terminating any transfer. It is configured as an open- 
drain driver, so requires a pull-up resistor, of an advised 
value of 4.7 kfl. 

As in the processor the DMA has a multiplexed address and 
data bus, also requiring an MM74HCT373 to latch the ad- 
dress. In this case it is the upper byte of the address bus 
which is multiplexed with the data bus. The strobe signal is 
similar to ALE but is generated in the DMA and called 
ADSTB (address strobe). The TRI-STATE for this latch is 
driven by the inverse of AEN, since the device must drive 
the bus only when the DMA has control. 
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2.0 Hardware (continued) 

The 9517 and 8237 have four DMA channels, of which only 
one Is used. The DRQ inputs for the other three channels 
are tied Inactive. The RESET Input causes the control regis- 
ters to be cleared and the D(=1Q inputs to be masked. 

2.1.4 EASI 

The E ASI Is controlled by setting Internal registers, written 
by an lOW and chip select, read by an lOR and chip select. 
The particular register selected is determined by the lowest 
three bytes of the address bus. The EASI has an eight bit 
microprocessor data bus, and on the PLCC part a micro- 
processor bus parity pin. However the NSC800 does not 
support parity checking so this bit i s tied lo w. The other 
microprocessor controlled pin is the RESET. This causes 
the EASI to clear all registers and therefore reset all logic. 
The DRQ output and DACK input "handshake" single mode 
DMA, while the READY o utput is used to control the speed 
of a block mode transfer. EOP is an input which terminates 
DMA, and can be used to cause an interrupt. This interrupt 
output INT can interrupt the microprocessor if the EASI de- 
tects an error, or has completed some task. 
SCSI uses an eight bit data bus with a parity bit; which must 
support odd parity during all bus transactions except arbitra- 
tion. Othe r SC SI sig nals are the bus selec tion control sig- 
nals SEL and BSY, phase co ntrol sign als M SG, C/D and 
170, data trans fer handshakes REQ and ACK and the mes- 
sage flag ATN. Further details on the use of these signals 
will be give n in t he software sections of this document The 
SCSI reset RST is similar to a chip reset, but generates an 
interrupt. 

The EASI Interfaces directly to the SCSI bus using high-cur- 
rent open-drain drivers. This bus is a 50-way ribbon cable 
(maximum length 6.0 meters) on which all SCSI devices are 
daisy-chained. The devices at the end of this cable must 
terminate the SCSI signals i.e., a 220ft resistor to power, 
and a 330n to ground. This power can be Vcc or 
TERMPWR (terminator power). 

TERMPWR is Vcc 'ed through a Schottky barrier diode. 
This can be fed to pin 26 of the connector allowing the SCSI 
device at one end of the bus to be powered down without 
affecting the bus. Since the terminators are receiving power 
the bus can operate effectively. To make this optional 
TERMPWR is fed to the connector through a jumper link. 
The Schottky diode must be included to prevent backflow of 
power into the printer controller board. 
Other manufacturers CMOS devices can not be used in 
a configuration like this, as they pull the bus low when 
not powered. The DP5380 and DP8490 have a special 
input protection to overcome this problem. 
All other pins on the connector should be tied to ground, 
except pin 25 which must be left floating. 

2.1.5 PIO 

The printer controller uses a NSC831 PIO to interface be- 
tween the processor and the printer. The NSC831 has 20 
individually programmable I/O bits which are arranged as 
three ports; A, B and C. As it is part of the NSC800 family 
the NSC831 has a compatible multiplexed address and data 
bus with an ALE input, to strobe the address into an internal 



latch. This eight bit address can then be used to a ccess an 
Internal register, in conjunction with an ISR or lOW and chip 
select. The device has two chip selects, one of which is tied 
active (low), with the other coming from the address decode 
PAL®. The RESET Input causes the three ports to become 
all inputs. 

In this application the three ports are set up so that each 
port is all Input or all output. Port A is an output, which drives 
the printer data bus through an MM74HCT241 octal buffer. 
Port B is an input, with the lower nibble coming from the 
printer outputs, driven by half an MM74HC T240 octa l invert- 
ing buffer. The pull-down resistors on the ERROR and PE 
(paper error) inputs give a proper error signal if the printer is 
unconnected i.e., the same as when the printer is off-line. 
The upper three bytes of Port B are connected to switches, 
which are used to set the board's SCSI I.D. This will be 
further explained in the SCSI diagnostics section. Only three 
bytes of Port C are used, all as outputs, driven by the same 
device used by Port B. Bits and 2 are printer outputs, while 
bit 3 drives a LED. This displays the 'health' of the board 
I.e., when the board is operational the LED is on, when non- 
operational It is off and when there is a known hardware 
error a message is 'flashed'. 

The printer connector is a standard IBM® 25 way 'D' range, 
with all unused pins grounded, except 13. 

2.2 PAL EQUATIONS 

2.2.1 Introduction 

PAL'S are used In this board to generate chip selects, over- 
come potential timing problems and to invert signals for de- 
vices with different active levels. The PAL's used are Na- 
tional Semiconductor's PAL16L8. The equations are written 
In a form compatible with PLAN (Programmable Logic Anal- 
ysis by National) Ver. 2.00. 

2.2.2 Decode PAL 

The decode PAL supplies the five main devices with their 
chip selects. 

Memory is split into two 32k byte blocks, each of which 
represents one device. These devices are an EPROM, at 
the base of memory, and RAM in the upper half. Thus the 
memory map and chip select equations are as follows: 

FFFFh 



8000h 
7FFFh 



OOOOh 

/EPROMZ = /A15''BACKZVI0MZ 
/RAMZ = A15*BACKZVI0MZ + A15 • AEN 
EPROMZ (the Z at the end of the name shows it is active 
low) can only be selected by the processor, while RAMZ is 
available to the DMA. 
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2.0 Hardware (continued) 

The DMA, PIO and EASI fit into the I/O map shown, which 
resuits in the equations foliowing. These equations show 
that the devices can oniy be selected by the microprocessor 
on an I/O cycle. 



FFh 



AOh 

80h 

40h 

20h 
OOh 



PIO 



DMA 



EASI 



/EASIZ = /A7 ♦ /A6 • /AS ♦ lOMZ * BACKZ 
/DMAZ = /A7 • /A6 ♦ A5 • lOMZ ' BACKZ 
/PIOZ = A7 • /A6 • /A6 • lOMZ • BACKZ 

The other three outputs are used as inverters: 
/BRQZ = HRQ 
/AENOZ = AEN 
/HLDA = BACKZ 

The two spare inputs are tied low. 



2.2.3 Control PAL 

The NSC800 uses lOM to d isting uish between memory and 
I/O cycles. This allows lOT and lOW, for processor cycles 
to be generated. 

/lORZ = /RDZ • lOMZ 

IORZ.TRST = BACKZ 

/lOWZ = /WRZ • lOMZ 

lOWZ.TRST = BACKZ 
The second line of these equations shows that the output is 
TRI-STATE when the processor relinquishes control of the 
bus. 

Before examining the next five equations it is important to 
fully understand the relative signal sequencing involved In a 
DMA transfer. When the transfer is initialed the EA SI Issues 
a DRQ, causing the DMA to r espon d with DACK, and take 
contro l of the bus by asserting BRQ. The processor asserts 
BACK and allows the bus and relevant control signals to go 
TRI-STATE. The DMA then asserts AEN, to show it is in 
control of the bus, causing the microprocessor address 
latch to TRI-STATE its outputs and the DMA latch to enable 
its outputs. 

For si ngle m ode each byte transferred must have a DRQ 
and a DACK. For block mode DRQ retu rns ina ctive after the 
DMA responds with a DACK, but the DACK must remain 
active until the transfer is complete. The READY line con- 
trols the rate of block mode DMA transfer i.e., when READY 
is low the byte transfer is 'frozen', until READY returns high 
(Figures 2. la and 2. lb). 

The READY signal is asynchronous but the DMA is synchro- 
nous, testing the READY signal on the negative edge of 
each clock. For this reason the READY input must be syn- 
chronized, using a flip-flop which updates its output on the 
positive edge of the clock. 

When READY Is detected as being inactive on the negative 
edge of the clock an extra cycle is inserted to the read and 
write. 

While data is being transferred a register keeps t rack o f how 
many bytes are left. When this reaches zero an EOP signal 
is generated, concurrent with the last read and write, caus- 
ing the EASI to set an EOP flag. 



J- 



WRITE* 



TL/F/100e2-2 



FIGURE 2.1a 



WRITE* 



FIGURE 2.1b 

■Note: 

Of these read and write signals, one wiil refer to memory the other I/O, depending on the direction of data transfer. 
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2.0 Hardware (continued) 

The tranfer is now complete so BRQ, AEN and DACK are all 
driven Inactive. AEN going inactive causes the address 
latches to swop back over; the microprocessor latch out- 
puts are driven, the DMA latch output s are TRI-STATE. 
When the micro processor detects that BRQ is inactive It 
deasserts BACK and retakes control of the bus. The micro- 
processor then decks flags in the EASI to determine the 
success, or othenwise, of the transfer. 
The other form of DMA available is pseudo-DMA; that is the 
EASI 'thinks' it is a proper DMA transfer but the processor is 
still in control of the bus. To do this the microprocessor 
must set the DMA to mask off any DRQ, initialize the EASI 
for single mode DMA and monitor the EASI flags for DRQ 
going acti ve. A t this point th e processor must generate an 
ISR or an lOW and a DACK, to properly simulate DMA. This 
can be done by causin g an I/ O read or write a t a ce rtain 
address, to generate a DACK, and if wanted an EOP. The 
particular address does not matter since during DMA the 
EASI ignores the address bus. 

The following equations generate pseudo-DMA signals, 
while allowing the true DMA signals to operate normally: 
/DACKOZ = /IORZ "• BAGKZ * /A7 * A6 

+ /lOWZ ♦ BACKZ • /A7 * A6 
+ /DACKIZ 
/EOP2 = /IORZ ♦ BACKZ • IK! * A6 • /A5 

+ /IOWZ • BACKZ • /A7 * A6 • /A5 
-I-/E0P1 ♦ EREADY 



DACKIZ is the DACK from the DMA, which the output nor- 
mally foll ows. T he rest of the equation generates the pseu- 
do-DMA DACK. 



E0P2 is the input to the EASI, E0P1 is the output from the 
DMA. The first two lines of this equation generate an EOP 
for the pseudo-DMA cycle, on the lower half of the address 
space that also generates the pseudo DACK. This means 
the final I/O map now is as follows: 

FFh 



AOh 
80h 
60h 
40h 
20h 
OOh 



PIO 



pseudo-DMA 



pseudo-DMA & EOP 



DMA 



EASI 



The third part of the EOP1 equation is to overcome a prob- 
lem that occurs during a block mode DMA transfer. On the 
last byte the READY signal from the EASI (this will be called 
EREADY to distinguish it from the READY into the DMA, 
D READY ) may be d riven lo w to freeze the transfer. Howev- 
er DACK, E5p and lOR or iOW will all be active causing a 
valid EOP condition. This is not a problem until we consider 
the next equation. 
/DREADY = /EREADY • /INT • /DACKIZ 



This equation causes the DMA READY input to go high if 
any of EREADY, SCSI inten-upt INT or DACKIZ go high. This 
overcomes a potential bus lockup, caused by an error oc- 
curring during a block mode DMA transfer. On a phase or 
parity error the EASI will stop the transfer and generate an 
interrupt. If DREADY is left inactive the DMA will keep con- 
trol of the microprocessor bus. This equation holds 
DREADY high on inten-upt, allowing the DMA to pass con- 
trol of the bus back to the microprocessor. 
Although this equatio n prevents an en-or it also introduces a 
problem in the E0P2 equation. As explained previously, dur- 
ing the last byte of a block mode transfer although READY 
is low a valid EOP condition may exist, which will cause an 
intermpt. This inten-upt will then cause DREADY to be driv- 
en high, allowing the DMA to finish the transfer, but lose the 
last by te since the EA SI is no t ready. To overcome this the 
EOP2 equation gates E0P1 with EREADY, so the EASI 
does not see a valid EOP condition until it is able to transfer 
the last byte. This problem does not occur In MODE E 
since it generates a true end of DMA interrupt. 
Another problem is introduced by the DREADY equation. If 
an error occurs during a DMA transfer the EASI will gener- 
ate an internjpt and DREADY will be forced high. This al- 
lows the DMA to 'run free', writing garbage into MEM ORY, 
and wasting SCSI bus time. To prevent this an external EOP 
must be applied to the DMA on error. The next equation 
does this: 
/E0P1 = /DACKIZ • /EREADY ' INT 
EOP1.TRST = /DACKIZ • /EREADY * INT 



E0P1 is an I/O pin which normally acts as input from the 
DMA, so the output is TRI-STATE unless DACKIZ and 
EREADY are low , with INT active. When this error condition 
occurs an EOP is output to the DMA, terminating the data 
transfer. A prerequisite of this equation working properly is 
the exis tence of the DREADY equation, since an externally 
applied EOP will have no effect on the DMA if READY is 
held low. 

The next equation is also required to prevent a fault occur- 
ring during a block mode DMA transfer: 

/EASIWRZ = /lOWZ * BACKZ 

-I-/IOWZ * EREADY ♦ /BACKZ 
Whe n the processor is in control of the bus a straightfor- 
ward IOW can write to the EASI, but if the DMA is in control 
EREADY must be high to allow the write. The inclusion of 
EREADY is required bec ause during DMA the EASI is a 
flowthrough latch; an IOW passes the data from the proces- 
sor bus onto the SCSI bus. Therefore if the DMA reaches its 
next byte before the data on the SCSI bus has been trans- 
ferred, th e DMA will ovenwrite the data. To prevent this 
EASIWR can only be allowed when EREADY is high. 
The final PAL output is used to invert the SCSI interrupt 
signal, to make this active high output compatible with the 
processor's active low input. 

/SCSIINTZ = INT 

3.0 Diagnostic Software 

3.1 iNTRODUCTiON 

The diagnostic software resides at the base of RAM, with 
the purpose of checking and initializing the printer controller 
board after power up and every hard reset. It must be at 
location zero, since after any hardware reset the program 
counter is cleared. The interrupt service routine is Included 
here, since it must exist at an exact locatton in memory. 



3.0 Diagnostic Software (continued) 

The software uses the NSC800 instruction set (fully Z80® 
compatible) which makes the required low level board oper- 
ations faster, and allows the exact positioning of code in 
memory. The assembler and linking loader are from Micro- 
tec Research. 

3.2 DEVICE CHECKING AND INITIALIZATION 

This section will refer to the diagnostic software 
PRINTER.SRC and the files PRNSYM.SRC and 
EASISYM.SRC which contain the constants used. A full list- 
ing of all programs described in this document are available 
on floppy disk. 

3.2.1 Memory Check and Interrupt Servicing 

An 'org' statement can be used to position this program at 
the base of ROM, address 0. After a jump to the ROM 
check, the next byte stores a label defining which version of 
the software is installed. On an EPROM the version numtier 
can be read from address 0002h. The upper and lower nib- 
bles should be considered as two numbers i.e., '10' defines 
version 1.0. 

The interrupts are disabled, since the service routines are 
not initialized, and the EPROM is checked; simply consisting 
of reading the same address twice and ensuring the same 
value returns both times. If this lest fails the system halts 
since a drastic error must have occurred. If the EPROM 
passes the test the program jumps to the RAM check. 
On interrupt the NSC800 stops before its next instruction, 
pushes the program counter onto the stack and loads it with 
a new address, depending on the highest priority interrupt 
channel active. Interrupt A, the only channel used, causes a 
jump to location 003Ch. The inten-upt service routine at this 
location pushes all of the processor registers onto the 
stack, and tests for a SCSI reset. SCSI reset must be 
checked, as this is a special condition, causing the board to 
tie reset by a general restart routine (this routine is in EAS- 
lO.SRC and explained in section 3.5). 
If the intermpt is not a SCSI reset the software makes a call 
to the bottom of RAM, where a jump command should be 
followed by a public variable RESET A. This variable can be 
loaded with the starting address of the routine to service the 
interrupt. On return from this routine the processor registers 
are popped back off the stack, and program control returns 
from the interrupt. Since RESETA is public any external 
software may use it, and therefore control which routine 
services an interrupt. RAM must be verified before this jump 
table is set up. 

The RAM test simply checks each BIT can contain a zero 
and a one, then clears every byte. Once RAM has been 
verified the stack pointer may be initialized, allowing call 
statements to be included. It should be remembered that 
although the intermpt routine is between the ROM and RAM 
tests, when the program runs it will jump straight from the 
ROM test to the RAM test. Since the intermpt jump table Is 
in volatile RAM the code for a jump instruction must be writ- 
ten into RAM after every reset. 

3.2.2 PiO initialization 

The file PRNSYM.SRC contains the port addresses for all of 
the I/O devices. The upper nibble contains the location the 
device takes within the I/O map, the lower nibble selects 
the register within the device to be accessed. 



The PIO has five types of registers which control data trans- 
fers through the device: 

1. Data Register — Each port has an eight bit data register 
containing the data passed between the PIO and the 
processor. These are either read or write registers, de- 
pending on whether the port bits are inputs or outputs. 

2. Data Direction Registers— Each port also has a data 
direction register which controls whether each of the 20 
bits is an input or an output (an input is defined by a zero, 
an output by a one). 

3. iMode Register — There is one three bit mode register 
which selects which of the four modes the device is in. 
This board will always require the PIO to be in Mode 
which is the basic I/O mode. The alternatives use Port C 
for handshaking. 

4. Bit Clear Register— Each port has an eight bit, bit clear 
register which clears any output bit whose corresponding 
bit in this register is high. 

5. Bit Set Register — These are similar to the above, but 
allow the output bits to be set. 

The PIO is set for Mode 0, with Ports A and C outputs and 
Port B an input. Port A drives the printer data bus, while 
Ports B and C read and write the printer con trol s ignals. The 
four printer outputs, to the Port B input, are ACK, BUSY, PE 
and ERROR. ERROR goes low when there is no paper, the 
printer is off-line or an error occurs; PE goes high when the 
printer is out of paper; BUSY goes high to show the printer 
can accept data; ACK pulses low to acknowle dge d ata after 
a byte has been transferred. Since BUSY and ACK are both 
handshake signals the user must decide which to use. This 
software will use BUSY. 

The top three bytes of Port B are used to read in the SCSIID 
from a block of switches. The SCSIID is the boards identifier 
on the SCSI bus, used in selection and arbitration, consist- 
ing of a single active bit. This is read in as a three bit num- 
ber, converted to the connect bit pattern and stored In a 
public variable called SCSIID. 

Port C is an output, dri ving the printer signals INIT and 
STROBE. A low pulse on INIT of 50 |a s causes t he printer to 
be initialized; a 500 ns low pulse on STROBE causes the 
printer to read the data on the bus. The highest bit of Port C 
drives a LED, which is on during board operation, and can 
display an error message by occulting a fixed code. Errors 
are displayed by the routine ERROR, a public function which 
displays the error number as a four bit code. It does this by 
occulting the LED for 1 second to show a 1, Va a second for 
aO. 

Since none of the PIO registers are true read/write the de- 
vice cannot be tested, only initialized. 

3.2.3 DMA Test and Initialization 

The DMA consists of address, word-count and control regis- 
ters for four channels, of which only one Is used. There 
follows a description of the registers used, with the address- 
es shown in PRNSYM.SRC. 

1 . Word-Count Registers— There are two word-count reg- 
isters; a sixteen bit write only base word-count register 
and a sixteen bit read only current word-count register. As 
with all sixteen bit registers in this device the two bytes of 
data are accessed by two successive selections of the 
same address. An internal flip-flop determines which byte 
is read or written, with the lower byte selected first after a 
reset. To transfer the con-ect number of bytes the word- 
count register must be written with the number of bytes to 
be transferred minus one. 
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3.0 Diagnostic Software (continued) 

2. Address Registers — The address registers are aiso six- 
teen bit, and called base and cun'ent. Ttie base address 
register is written witti the address the transfer must start 
at, while the current address register contains the next 
address to be written or read. The DMA is tested by writ- 
ing a value to the base address and reading It back from 
the currant address. 

3. Control Registers— There are three types of control reg- 
ister which will be discussed only in the way they are used 
by this software. The master clear register (DMAMCL) is 
the software equivalent of a hardware reset; all registers 
are cleared and DRQ Is masl<ed off. Masking of DRQ is 
controlled by the parallel mask register (DMAMSK), in 
this case always used to allow DRQ on Channel and 
mask off the others. The final type of register used is the 
mode register (DMAMOD) which controls whether a 
transfer Is block or single mode, memory read or memory 
write. Each of the four channels has a six bit mode regis- 
ter, all at the same address, with the bottom two bits of 
the data bus determining which Is selected. 

The DMA test program initializes the device for a one byte, 
block mode, memory write, to an address TSTBYT. The 
DMA is Initialized in this particular manner for use In the 
EASI loopback DMA test routine. 
An error in DMA test will cause error signal 0. 

3.3 EASI TEST AND INITIALIZATION 

3.3.1 Introduction 

This document will show how the registers within the 
DP5380 and DP8490 are used in an application. For a full 
register description refer to the DP5380 and DP8490 data- 
sheets. Register names and their locations are given in 
PRNSYM.SRC. 

3.3.2 DP8490 and DP5380 Test 

The DP5380 and DP8490 are completely pin and hardware 
compatible, and also software compatible until the en- 
hanced mode bit is set In the DP8490. The DP8490 powers 
up In normal mode (MODE N which is software compatible 
with the 5380) and is In MODE N after any chip reset. The 
Initial test is therefore the same for both devices, writing to 
the Mode Register 2 (EASIMR2) and reading back the data. 
The EASIMR2 is selected since it has the most read/write 
bits that do not directly affect the bus. 
An error in EASI test will cause error signal 1. 
For the DP5380 testing Is now complete, but the DP8490 
enhanced mode offers a loopback test facility, where the 
SCSI drivers are disabled and the SCSI i/O's looped back 
inside the EASI. Using this feature the user can fully 
check the device, and by doing a DMA transfer fully 
check the board. 

At this stage It is therefore neccessary to determine which 
device is inserted. In the DP5380 bit 6 of the Initiator Com- 
mand Register (EASIICR) selects the 'test mode', which dis- 
ables all output drivers on the device, making it invisible to 
the system. Although the device can still be written to no 
data can be read back, making applications very limited. In 
the DP8490 this bit selects the enhanced mode (MODE E) 
of the device. 

In MODE E addresses 0-6 access the same registers as in 
MODE N, but address 7 is different. Instead of accessing 
the Reset Parity/Interrupt (EASIRPI) and Start DMA Initiator 
receive (EASISDI) registers, address 7 directly accesses the 



Enhanced Mode Register (EASIEMR) and indirectly access- 
es the Interrupt Mask Register (EASIIMR) and Interrupt 
Status Register (EASIISR). The only other difference to reg- 
isters occurs in the Target Command Register (EASITCR) 
where one of the previously unused bits becomes a flag 
(explained in section 3.3.4). 

To test which device Is Inserted EASI test sets the en- 
hanced/test mode bit, writes data to address 7 and reads 
back from the same address. If the device Is a bPS380 it will 
be In 'test mode' and the data read will be OFFh due to the 
pull-up resistors on the data bus. If It Is a DP8490 the data 
read back will be the data written, providing the only bits set 
are read/write. For a DPS380 the program jumps to initiali- 
zation for selection; if It is a DP8490 loopback testing fol- 
lows. 

3.3.3 DP5380 Initialization for Selection 

The DP5380 Initialization involves programming the device 
to respond to a selection. First, the public variable DP8490 
(which other programs should treat as a constant) is set 
FALSE to indicate that a DP8490 is not inserted. For the 
DP5380 to be selected it must have the SCSIID of the de- 
vice in Its Select Enable Register (EASISER) and parity 
must be enabled. The processor must enable its inten-upts 
and set up the jump table; IntA is an external routine which 
sets the processor's interrupt mask to only allow interrupts 
on A, and enables the interrupts (see EASIO.SRC); main^ 
is an external program which responds to a SCSI selection 
(further explained in the Run-time software section). 
If BSY Is inactive for a bus settle delay (400 ns), SEL is true 
and the bit on the data bus corresponding to the SCSIID Is 
active, a SCSI selection interrupt is generated. This causes 
a processor interrupt, taking the program from the continu- 
ous 'jr Now' instruction to the interrupt service routine, and 
through the jump table to maln_ When main_ has finished 
servicing the internjpt it will return to the interrupt servicing 
routine and then return from the interrupt. Thus the board's 
'Idle' state is to continually execute the 'jr Now' instruction. 

3.3.4 DP8490 Loopback Test 

The loopback test mode of the DP8490 allows all signals to 
be fully tested, including a DMA transfer, without affecting 
the SCSI bus. To allow this DMA transfer loopback allows 
the user to drive both initiator and target signals simulta- 
neously. 

After setting the DP8490 flag true all initiator signals, and 
then target signals, are asserted and checked. This Includes 
a check on the data bus by writing a test value to it and 
reading it back. The data bus test value has an odd number 
of bits, and since the specified SCSI parity is ODD, the parity 
bit must be inactive. One of the new features offered in 
MODE E is programmable SCSI parity, which Is tested by 
ensuring the parity bit becomes active when EVEN parity is 
enabled, and inactive when a test value with an even nurn- 
ber of active bits is written. Parity is then returned ODD, and 
the parity bit should become active. 
An error in Loopback testing causes error signal 2. 
The next test in loopback mode is a DMA target receive 
transfer to a location In memory, TSTBYT. This not only 
tests the EASI, but also the interrupt servicing, the DMA and 
memory. Although the device is in loopback the software 
must carry out the trans fer as it would normally i.e., the bus 
phase must be correct, BSY must t)e active and the SCSI 
bus must be asserted. The EASIUR2 must be properly set 
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3.0 Diagnostic Software (continued) 

up for block mode DMA, with Interrupt on EOP or parity 
error. Since this test is Intermpt driven the Interrupt jump 
table must be loaded with the address of the routine which 
will service the DMA loopbacl< test, and the Interrupts must 
be enabled. The DMA has already been initialized for this. 
Before enabling interrupts the SCSI interrupts should be re- 
set, which In MODE N would involve reading address 7. 
Since the EASIEMR is now at this address the resetting of 
interrupts, and the start of DMA Initiator receive are Initiated 
by writing to function bits of the EASIEMR. 
When the Start DMA Target receive (EASISDT) register Is 
written the EASI will issue a REQ to show it is ready to 
receive data on the SCSI bus. At this point t he de vice at the 
other end of the bus would normally assert ACK to show It 
has data available. In t his ca se there Is no other device so 
the u ser must wait for REQ to go active and then assert 
ACK. Thus both initiator and target signa ls must be asserted 
simultane ously. The user waits for REQ to go inactive, and 
deasserts ACK to show the bus transfer Is complete. 
The program then goes Into a continuous loop awaiting a 
SCSI Interrupt. This Interrupt wi ll occ ur because the EASI 
will have Issued a DRQ, when ACK went active, and the 
DMA wil have transferred the last t est b yte written to the 
EASI to TSTBYT, finishing with an EOP. On Interrupt the 
program will jump to address 003Ch, where all the proces- 
sor registers are pushed onto the stacl<, a call Is made to 
the base of RAM, and from there It will Jump to the subrou- 
tine DIAGA. 

One of the problems w ith DM A in a DP5380 Is th at en d of 
DMA is flagged when DACK, EOP and lOR or lOW are 
simultaneously active; although the data may not yet have 
been transfen-ed on the SCSI bus. To overcome thi s the 
soft ware must examine the SCSI handshake signals REQ 
and ACK, both of which must be Inactive on three succes- 
sive samples for a true end of DMA. This is more fully ex- 
plained in the DP5380 and DP8490 datasheets. MODE E of 
the DP8490 detects true end of DMA, after ACK goes 
Inactive, before generating an interrupt. 
DIAGA responds to the Interrupt after the loopback DMA by 
checking all the correct flags have been set. The DP5380 
only uses four bits of EASITCR so MODE E uses the free bit 
7 as a flag, to show true end of DMA. This is the first flag 
checked. Address 7 not only directly addresses the 
EASIEMR It also indirectly addresses the EASIIMR and 
EASIISR. After writing the correct code to the function bits 
of the EASIEMR the next access of address 7 will be to the 
EASIISR, if It is a read, or the EASIIMR, if It Is a write. The 
advantage of the EASIISR over the DP5380 registers Is 
that all Interrupt information is available In one register, 
and every interrupt is flagged. To check DMA the user 
need only read the EASIISR and ensure that the only flag 
active Is end of DMA. The user should note that SCSI reset 
causes the device to revert to MODE N, from which the 
EASIISR can not be read, so Is not flagged. 
The final EASI flag test Is the 'conventional' end of DMA 
flag In the Bus and Status Register (EASIBSR). This flag, 
the Interrupt flag and the flag to show no phase mismatch 
has occurred must be the only bits active. The final loop- 
back DMA test Is to ensure that memory location TSTBYT 
contains the correct data. 
An error In Loopback DMA test causes en-or signal 3. 



3.3.5 DP8490 Initialization for Selection 

The DP8490 Initialization Is very similar to that of the 5380, 
even calling the same routine, maln^ , to respond to selec- 
tion. However, this device stays In MODE E and uses these 
enhancements to only allow Interrupts on selection and par- 
ity by setting the EASIIMR. Selection and parity are the only 
valid Interrupts at this point. 

At the end of the DIAGA routine program control returns to 
the 'jr Here' Instruction, which it will continually enact until a 
parity or selection interrupt causes a jump to ma//7__. 

3.4 ERROR HANDLING 

Throughout all software for this board the error handling Is 
the same for errors considered non-recoverable, which in- 
cludes all errors in diagnostics. On error the board continu- 
ally displays an error number, as a four bit binary code, us- 
ing the LED. The subroutine ERROR carries out this func- 
tion. 

On error register 'I' should be loaded with the error number 
and routine ERROR called. This routine then occults the 
LED for % second to display a zero, 1 second to display a 
one, with the LED on for Va second between flashes. The 
four bits, most significant bit first, are repeatedly displayed 
between 2 second intervals, during which time the LED is 
on. The timing delays are generated using a routine DELA Y, 
which gives a number of V^ second delays, the number of 
delays being determined by the value in the 'I' register. 
The following list shows the possible en-ors In diagnostics. 
The run-time software section contains a similar listing of its 
error codes. 
Error 

The DMA can not be accessed. 
Error 1 

The EASI can not be accessed. 
All other diagnostic en-ors concern a DP8490 
Error 2 

An error has occurred In the assertion of SCSI signals In 
loopback test mode. 
Error 3 

An error has occurred during the loopback DMA transfer. 

3.5 EASIO.SRC 

This file contains public assembly language routines, which 
can be called by either the diagnostics or run-time software, 
to Implement low level commands. As these routines may 
need to be called by routines written in 'C any variables 
passed to the routines are passed In the 'hi' register pair, 
then In 'de', then 'be' and then on the stack. ERROR and 
DELAY boVn use the 'I' register to pass a variable. Data 
passed back to the calling routine is returned In the accumu- 
lator. 

Functions 'read' and 'itnte' Implement general purpose I/O 
register accesses, while 'dmaread' and 'rfmanr/te'^handle 
the special case of the 16-bit DMA registers. These require 
two accesses of the same address. 'intA' initializes the 
processor interrupt mask, with a 'pseudo' I/O write, which 
selects a register internal to the processor, setting the mask 
to only allow Intermpts on RSTA. This function also enables 
the Interrupts, which can be done by 'en/', with 'dsi' dis- 
abling Interrupts. 

'IDtest' is used by the run-time software, during selection, to 
read the number of bits active on the bus. This routine 
checks the number of high bits in the byte passed In the 'I' 
register, returning the value in the accumulator. 
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3.0 Diagnostic Software (continued) 

Function 'restrt' is a general purpose reset routine, which 
can be called on an error condition. This causes every de- 
vice on the board to be reset, and the diagnostics to be re- 
run, thus clearing all memory and reinitializing the stack. 

4.0 Run-Time Software 

4.1 INTRODUCTION 

Following the diagnostic software must be a program which 
will control all SCSI bus transfers, beginning with selection. 
This program is written In 'C, using a PARAGON 'C cross 
compiler for an NSC800. The relevant files for this section 
are SCSI.C, COMMAND.LIB, PROCESS.LIB, DMA.LIB, 
PRINT.LIB, ARBITRAT.LIB, SYM.H, CONST.H and COM- 
MANDS.H, all of which are on the supplied floppy disl<. 
SCSI.C contains the main program, called 'main' by 'C and 
'main_' by assembler. The '.LIB' files contain the functions 
called by main and the '.H' files contain the constant values 
used by all of these files. 

4.2 MANDATORY PHASES 

This section outlines all the bus phases and transfers which 
a target must support. It would be perfectly legal for a target 
to respond to a selection, fetch a command block from the 
initiator, and then returns status and message bytes before 
releasing the bus. Although no process would be actuated 
this would be a legal sucession of events. 

4.2.1 Selection Response 

mainO is the program jumped to when an internjpt is gener- 
ated as the program circles the continuous loop at the end 
of diagnostics. This routine should only be entered after a 
selection interrupt, if any other internjpt is active it is consid- 
ered an error. The function selectO checks an intermpt to 
ensure it is valid. 

The type of device installed is checked by reading the 
'DP8490' flag, and this determines how the inten-upt is veri- 
fied. In a DP5380 a selection inteffup t is d etermined by the 
absence of any other interrupt, with SEE active. The user 
must check the EASIBSR to ensure that no en-or flags are 
active, only the INT and PHSM (phase match) bits. 
Any other flag will cause error number 4 to be displayed. 
After reading the EASIBSR and finding no inten-upt flags the 
user knows the intenupt should be a selection. The only 
other unflagged interrupt is a reset, which would have been 
handled by the low level interrupt service routin e. Th erefore 
the EASICSB register must also be read, and if SEL is inac- 
tive an error condition exists. 
This causes error number 5 to be displayed. 
In MODE E the user need only read the EASIISR to de- 
termine which Interrupt is active, including selection. All 
interrupts, other than parity and selection, should be 
masked off, so any error concerns only these two flags. 
A SCSI parity error is displayed as error number 8, if the 
selection flag is not active error number 9 is displayed. 
The common tests for MODES E and N both concern the 
EASICSD; en-or 6 shows that the con-ect SCSIID bit was not 
active on the bus; en-or 7 shows there was more than two 
bits active on the bus. During selection an initiator is only 
allowed to assert two bits on the bus, its own ID and the 
target ID. 



The target must assert BSY to show it has reco gnized the 
selection, then when the initiator deasserts SEL the selec- 
tion phase is complete. 

4.2.2 Command Phase 

A selection phase is followed by a command phase, where 
the target reads a command block from the initiator. This 
command block specifies the actions the initiator requires 
the target to execute, plus the length of any data transfers 
requested. This board only allows six byte command blocks, 
which are transferred into the target by function fetch.^ 
omd(). 

The command block is transfen-ed using programmed I/O; 
that is each byte is individually handshaken under processor 
control. The bus phase must be Command Out (out and In 
always refer to the initiator, so Command Out is a command 
block sent by the initiator), bus phase being set in the 
EASIT CR.T transfer a b yte (s ee Figure 4. 1 ) the user must 
assert REQ, t hen w ait for ACK to go active to show data is 
available. On ACK t he target can read the data on the bus, 
then deassert REQ to show it has received the data. When 
the initiator deasserts ACK the byte transfer is complete. 

4.2.3 Status Phase 

The target must send a status byte to the initiator during the 
status phase, at the termination of each command. A list of 
status codes is given in COMI\/IANDS.H. statusO is the 
function which enters a Status In phase, and transfers the 
code. 

The EASITCR must be written with the Status In phase and 
the EASIODR with the status code. This c ode s hould be 
asserted onto the bus, rememberin g to k eep BSY asserted, 
and if neccessary the MODE E bit. REQ is then asser ted to 
show data is available. The initiator should assert ACK when 
it has read the data, allowing the target to deassert REQ 
and take the data off t he bu s. The transfer is complete when 
the initiator deasserts ACK (See Figure 4.2). 
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4.0 Run-Time Software (continued) 

4.2.4 Message Phases 

A selection must be terminated by the target entering the 
Message in phase, and sending a relevant message code 
(as listed in COMMANDS.H). The target follows the Status 
phase with the Message In phase, usually to send the COM- 
MAND COMPLETE message. This indicates valid status ex- 
ists, so the target can release BSY to free the bus. messin() 
enters the Message In phase and sends the message using 
programmed I/O, as in status(). 

The only message which must be supported is COMMAND 
COMPLETE. If a device on the bus supports ot her m es- 
sages it indicat es this by responding to or asserting ATN. An 
initiator asserts ATN if it has a m essa ge for the target. It is 
common for an initiator to assert ATN during selection and, 
if the target responds by entering a Message Out phase, it 
sends the IDENTIFY message. This establishes whether 
the target can respond to a greater set of messages, and 
whether the initiator supports disconnection. It shows this 
by setting bit 6 of the message. In a disk controller IDENTI- 
FY would also establish the path by including a Logical Unit 
Number (LUN), but the printer controller uses all LUN's at 
this SCSIID. 

getmesO enters a Message Out phase and fetches a mes- 
sage using programmed I/O. Although this software only 
supports single byte messages it must be prepared to ac- 
cept messages from the initiator of up to the maximum 
length, 256 bytes. If an initi ator w ishes to send further bytes 
after the first It must keep ATN asserted, only deasserting 
after the final byte has been transferr ed. g etmesQ will 
handshake up to 256 bytes, after which If ATN Is asserted It 
will be considered an error. Only the first byte Is used in 
determining the message sent. 

The use of messages during disconnection, arbitration, re- 
selection and in error handling will be discussed In those 
sections of this document. 

4.2.5 Command Termination 

After sending status and m essa ge codes to the Initiator, the 
target should then release BSY to free the SCSI bus. How- 
ever, before allowing a bus free phase the target must ini- 
tialize Itself for the next selection, as in function reset(). 
The interrupt jump table Is loaded with main() and the 
EASISER with the SCSIID. For a MODE E device the inter- 
rupt mask Is set. For b oth types of device the Interrupts 
must be reset, and BSY deasserted. Interrupts are disabled 
at the start of this function, so must be enabled after calling 
r0set(). 

4.3 COiMiUAND PROCESSiNG 

After the command block has been fetched the command 
has to be determined and executed. The printer command 
set is shown In COMMANDS.H. 

process_pmd( ) reads the first byte of the command block 
which contains the operation code. This determines what 
actions are taken. If a command has been sent which this 
software does not recognize, a status of CHECK CONDI- 
TION Is returned, with sense set to ILLEGAL REQUEST. 



4.3.1 Test Unit Ready 

TEST UNIT READY will be sent by an Initiator before a print 
to ensure the printer is on, on-line, has paper and Is not In 
an error condition. On this command the function ck_print- 
erO Is called to read the printer signals through Port B of 
the PIO and check for errors. 

If the en-or line Is not high the printer Is operational, so the 
status is GOOD, and the sense Is set to NO SENSE (no 
error). If there is an error the paper error line must be 
checked. If this is low (active low Input) the printer is out of 
paper and status of CHECK CONDITION is returned, with 
sense set to MEDIUM ERROR. If It Is not a paper error the 
printer Is assumed to be off or off-line, so status is CHECK 
CONDITION with sense UNIT ATTENTION. 

4.3.2 Request Sense 

An Initiator will send a REQUEST SENSE command after 
the target has returned a status of CHECK CONDITION. 
The sense data is sent to the initiator in an effort to under- 
stand an error condition, and If possible recover from It. Byte 
4 of this command block contains the length of an extended 
sense message, which must not be greater than 4, or sense 
is set to ILLEGAL REQUEST and CHECK CONDITION 
status returned. This software only supports four bytes of 
sense data. 

Sense data Is sent to the Initiator using single mode DMA. 
The DMA Is Initialized by send^sense(); it Is reset by a 
master clear, the mode set, the DMA mask written and the 
address and word-count loaded. The function s/ng/e_ 
dma^nO (explained In section 4.4.1) enters the correct 
phase (Data In) and transfers the data. 

4.3.3 Reserve Unit 

In a multi-Initiator system a printer controller must be re- 
served before a print commences, or the data from two dif- 
ferent initiators may be mixed. This command stores the 
initiator's ID In a variable called 'reserved', and on subse- 
quent selections only this Initiator may execute commands. 
Any initiator wishing to reserve the unit must put Its own ID 
on the bus during selection, along with the target's ID, so 
this software knows which Initiator is reserving the unit If 
the initiator's ID is not on the bus it can not reserve the unit, 
and since this Is a prerequisite of printing. It cannot use the 
printer. 

If an initiator attempts to reserve this unit without making Its 
ID available sense Is set to ILLEGAL REQUEST and status 
of CHECK CONDITION returned. If another device attempts 
to reserve the board when It Is already reserved status re- 
turned Is RESERVATION CONFLICT. 

4.3.4 Release Unit 

This is the reciprocal command to the previous, freeing the 
printer for other initiators after a print has been completed. If 
an initiator other than the reserver attempts this command a 
status of RESERVATION CONFLICT Is returned; If this Is 
attempted when there Is no reservation current the returned 
status Is CHECK CONDITION with sense set to ILLEGAL 
REQUEST. 
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4.0 Run-Time Software (continued) 

4.3.5 Print 

Since transferring data to a printer is a very slow process, 
typical Epson Fx range 80 cps-160 cps, the print command 
transfers the data to a buffer, leaving it to be printed later. 
Bytes 2, 3 and 4 of the command block contain the data 
length, byte 2 the most significant. The use of three bytes to 
define the size means that in theory block transfers of up to 
16 MB are allowed. This software could support blocks of 
up to 64 kB, bytes 3 and 4 are read, but blocks are limited to 
a size BUFFLIM, which will be determined in section 4.4.3. 
Possible errors in a print occur when the unit is not re- 
served, the data length is set to zero, or the block size is too 
large. The block size is too large if byte 2 of the command 
block is active or if the data length is greater than BUFFLIM. 
In response to an error the transfer is cancelled and status 
of CHECK CONDITION is returned with sense set to ILLE- 
GAL REQUEST. 

The data is not transfen'ed unless sense is set to NO 
SENSE. If an error has occurred in the printer sense will 
have been set to indicate the error source. The error condi- 
tion must be rectified and TEST UNIT READY sent to reset 
the sense data. 

print_cind() is the function which transfers data into a buff- 
er using block mode DMA. The print buffer is a circular 
queue, allowing the user to take data off the front and put 
data on the rear (see Figure 4.3). 
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front points to the next byte to be printed, rear points to the 
next available byte for entering data. When front equals rear 
the queue is empty, when rear is one less than front the 
queue is full. 

The buffer limits are called top and bottom. When either the 
front or rear pointers reach the top the next increment takes 
them to the bottom. Thus the queue may look like Figure 
4.4. 
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When print_cmd() is first called after a reset it must set up 
the queue, defining top and bottom, and setting front equal 
to rear equal to bottom. Before any transfer the data length 
must be checked to ensure that the DMA will not take rear 
past top. If it would the data must be transfen'ed in two 
blocks; one to the top of the queue, and one starting at the 
bottom of the queue. This routine should not be called un- 
less there is sufficient free space for the size of transfer. 
Function drt\a^slata() sets up the EASI and DMA for a 
block mode transfer, enters the Data Out phase and calls 
dma() to handle the transfer. This will be more fully ex- 
plained in section 4.4. 

4.3.6 Flush Buffer 

The purpose of this command is to allow an initiator to ter- 
minate an unwanted print. An initialization pulse is sent to 
the printer, in case It has its own buffer, and the SPC buffer 
is cleared. This is done by setting front equal to rear equal 
to bottom. 

4.4 DATA TRANSFERS 

This section is concerted with the way in which software 
controls DMA transfers, both block and single mode, and 
how the print data block length is determined. 

4.4.1 Single Mode DMA 

The four bytes of sense data are sent to the initiator using 
single mode DMA. send_sense() sets up the DMA to 
transfer four bytes of data from the sense buffer to the 
EASI, leaving function singie_clma_jn( ) to complete the 
transfer. 

The phase, which in this case is Data In, is determined by 
the calling function, and the EASIMR2 initialized for a single 
mode transfer. Parity checking is enabled with inten-upt on 
EOP or parity error. The data bus is asserted and the routine 
dma() is called to handle the transfer. 
Since both single and block mode DMA transfers, either in 
or out of the initiator, have large portions of code that are 
common, a function can be written for general purpose 
DMA handling. This function, dma(), sets up the interrupt 
response and makes a write to the register which initiates 
the required type of transfer, which could be target receive 
or target send etc. dma() checks the success of the trans- 
fer when the transfer is complete. 
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4.0 Run-Time Software (Continued) 

In MOD E E the Inten-upt mask can be set to only allow pari- 
ty, EOP and DMA phase mismatch Interrupts. The Internjpt 
jump table Is loaded with the starting address of a service 
routine, which sets a flag to show an interrupt has occurred. 
The program can then sit In a loop waiting for this flag to go 
active. 

After the Inten-upt the cause has to be checked to ensure 
the transfer was successful, but this checking depends on 
the device Installed. For a DP8490 the user can read the 
EASIISR and If any flag other than end of DMA Is active an 
error has occurred. On such an en-or, status Is set to 
CHECK CONDITION with a sense of ABORTED COM- 
MAND. The Interrupt mask can be reset, masking off end of 
DMA and DMA phase mismatch, and the DMA mode In the 
EASIMR2 disabled. The Inten^ipt service routine Is set to 
jump to the general Interrupt handler gen_int(). The Inter- 
rupt must then be reset and the processor's Interrupts en- 
abled. 

In MODE E true end of DMA Is detected, but in M ODE N the 
end of DMA interrupt Is generated when EOP, DACK and 
lOR or low are active concurrently. True end of DMA, after 
the transfer is complete, must be detected by software. 
REQ and ACK must both be inactive on three successive 
samples for true end of DMA. This additional code makes 
the MODE N DMA routine slower. After detecting this the 
user can check the end of DMA flag Is active In the EA- 
SIBSR, giving status CHECK CONDITION and setting sense 
ABORTED COMMAND If it is not. The DMA bit Is then reset 
and gen^ntO called to ensure there was no parity or 
phase errors, and to reset the Interrupt service routine. 
On return to the function single^ma_Jn( ) It will deassert 
the SCSI bus and return to the calling routine. 

4.4.2 Block Mode DMA 

blk^ma^nO is the equivalent routine to single_dma^ 
ln() initiating a block mode transfer to the initiator, send^ 
senseO could call this routine, after setting the DMA for 
block mode, and transfer the data using block mode, with 
no difference to the other software. The only difference be- 
tween these two routines Is the setting of the EASIMR2 BLK 
mode bit. 

prlnt_x!md() Is used to transfer the data to be printed from 
the initiator. This function checks that the transfer will not 
exceed the constraints of the queue and calls dma_jdata() 
to initiate a block mode transfer. dma_jiata() sets the EASI 
and DMA registers for a block mode target receive, with the 
data size set by print.^md() and the destination starting 
address equal to rear. dma() Is again used to handle the 
Interrupts. 

4.4.3 Determination of Data Block Length 

The block of data to be transferred for a print has been 
specified as a maximum length of BUFFLIM, but the value 
of this constant has to be evaluated. The two main consid- 
erations in this are the latencies of the bus and the SPC. 
Since this board is a printer controller It will be of a very low 
priority. Thus the device should not hold the bus for too 
great a time per transfer, as this would slow down Initiator's 
accesses of a high priority peripheral. The second consider- 
ation Is the time that the target takes from selection to en- 



tering a data phase, the data block must take longer than 
this to transfer, or the command Is Inefficient. Measure- 
ments taken on various models of personal computers 
showed that, with an Advanced Storage Concepts 
ASC-88TM SCSI Hos t Adaptor, the time taken from the ini- 
tiator asserting SEL to the target commencing the data 
transfer is approximately 3 ms. 

The block mode DMA rate was measured as between 
200 kB/s and 500 kB/s limited by the DMA In the PC. A 
block length of 2 kB was selected, since this would take 
between 4 ms and 10 ms to transfer. Thus the data transfer 
time is greater than the selection to data phase time, but the 
overall time on the bus In not too long. 

4.5 PRINTING DATA 

Due to the Inherent slowness of printers data can not be 
printed while the controller is in command of the SCSI bus. 
To prevent tying up the bus data Is stored In a buffer and 
printed after BSY has been released. The function printit() 
handles the transfer of data to the printer. 
printitO checks the printer is not In an error condition, and 
transfers the byte of data at address front to the printer. The 
data is tra nsferred through Port A of the PIO with BUSY and 
ST ROBE use d to handshake the data. BUSY must be high 
and STROBE pulsed low a minimum of 0.5 \xs for the printer 
to accept data, front is Incremented, to point to the next 
byte to be transferred. To print out the queue printitO is 
called until front equals rear. 

If the function does detect an error It sets sense to the 
appropriate value, and Implements any outstanding recon- 
nection. The printer Is continually polled to determine when 
it comes back on-line, at which time the print continues. 
While the board is printing it must still be available for selec- 
tion. An Initiator can reset every device on the SCSI bus If a 
target does not respond to a selection within a Selection 
Timeout, normally 250 ms. The interrupt service routine has 
been set to jump to main(), but the program is currently In 
main(), so this function must be re-entrant. 
maInO is written in such a way that it will only process com- 
mands If It is unresen/ed and not printing, or reserved by the 
current Initiator but not printing. If the board Is reserved, but 
not by the current initiator, a status of RESERVATION CON- 
FLICT is returned. If the board is printing, and the reserving 
initiator attempts to send It another command a status of 
BUSY can be returned. 

However, the controller has a 30 kB print buffer, of which 
only 2 kB would be used at a time. It would be much more 
efficient to continue executing commands until the buffer Is 
full. One method of achieving this can be seen in outbuff). 
In this function a flag, called next. Is set If the free space in 
the queue Is greater than BUFFLIM. If a selection occurs 
while a print Is on, this flag Is checked and the command 
processed if it is active. If It is inactive a status of BUSY is 
returned. This method has the disadvantage that the initia- 
tor must continually poll the SPC to determine when it is 
ready to accept data. This 'loads' the SCSI bus and slows 
down the print, since the SPC will be responding to selec- 
tion. It also restricts other device's use of the bus. The alter- 
native method of utilizing the buffer space Is to use discon- 
nection and reconnection. 
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4.0 Run-Time Software (continued) 

4.6 DISCONNECTION AND RECONNECTION 

4.6.1 Disconnection 

If an initiator sends tlie IDENTIFY message to the target, it 
can indicate that it supports disconnection by setting bit 6 of 
this message. If this bit is not set, or ths* message not sent, 
the Initiator Is assumed not to support disconnection, and 
no disconnection is attempted. This software uses discon- 
nection in two places; 1) the board is reserved, currently 
printing and selected by the reserving initiator; 2) the board 
has been released, but not finished printing. 
If the board is busy printing it can be advantageous to dis- 
connect from the reserved initiator after reading in the com- 
mand block, and then reconnect having ensured that the 
command can be implemented i.e., there is enough free 
space in the queue. For any other initiator the response is 
the same as before, the status of RESERVATION CON- 
FLICT is returned until the unit is released. After this the 
controller will disconnect from any initiator attempting to se- 
lect it, until it has enough free space in its buffer. 
disconnectO is the routine which carries out the disconnec- 
tion procedure. This can only take place after the command 
phase and before the data phase, with an initiator that sent 
the IDENTIFY message with the disconnection bit set. The 
target follows the Command Out phase with a Message In 
phase an d sen ds the DISCONNECT message, after which it 
can drop BSY, to release the bus. If the DISCONNECT mes- 
sage is not sent the initiator will treat the deasserting of BSY 
as an illegal termination of command. Before releasing BSY 
exchangeO is called to store the ID of the initiator and the 
command it wants to execute. r esetQ is again used to ini- 
tialize the interrupts and release BSY. 

disconnectO stores in a variable, recon data, the amount 

of print buffer which will be required to execute the com- 
mand. For a print, this depends on the length of data to be 
transferred, for any other command the amount is zero, re- 
con data is used to determine when the target can recon- 
nect to the initiator i.e., once there is enough space free in 
the buffer. 

After disconnection the program will return to printing, at 
which point it may be selected by another initiator. As it can 
only disconnect from one initiator at a time it must return a 
status of BUSY. 

in outbufO it can be seen that reconnection takes place 
when the free space in the print buffer is greater than the 
number of bytes to be transferred. reconnectO calls the 
functions which action the correct reconnection procedure, 
beginning with arbitration. 

4.6.2 Arbitration 

Arbitration requires two functions, one for MODE E another 
for MODE N, due to the fundamental difference in their 
methods of arbitration i.e., MODE E is interrupt driven, 
MODE N is polled. These two functions, NarbitrateO and 
EarbitrateO, carry out the same basic operation, arbitrate 
for the bus until successful, but do so in distinctly different 
ways. 

To arbitrate f or the bus a device must wait for a Bus Free 
Phas e, when BSY is continuously inactive for 400 ns with 
SEL inactive. After a Bus Free Delay of 800 ns the SCSI 
device should assert BSY, and assert its SCSIID bit on the 



bus. After a further 2.2 fts Arbitration Delay the data bus 
should be examined, and the device with the highest priority 
SCSI ID bit asserted wins arbitration. 
In MODE N the EASIODR should be written with the SCSIID 
and the arbitration bit in the EASIMR2 set. The intermpts 
must be initialized to cause a jump to routine servn(). The 
EASI will wait for a B us Fr ee Phase then, after a Bus Free 
Delay, it will assert BSY, and put the contents of the 
EASIODR onto the bus. The user must poll the AlP bit of the 
EASIICR to determine when arbitration has begun and 
check the LA bit to ensure that arbitration h as no t been lost. 
The LA bit is set if another initiator asserts SEL during arbi- 
tration. If AlP is active and LA inactive the user must exam- 
ine the EASICSD to determine whether it is the highest pri- 
ority device arbitrating. If arbitration is lost the arbitration bit 
in the EASIMR2 must be reset and the whole procedure 
begun ag ain. T he device shows It has won arbitration by 
asserting SEL. An intermpt during MODE N arbitration is 
treated as a selection, so servn() enables parity, since there 
is no parity checking during arbitration, and calls main(). 
In MODE E arbitration Is interrupt driven, allowing the 
board to continue printing while waiting to arbitrate. 
For a busy SCSI bus typically many milliseconds, and 
potentially many seconds, can be taken up arbitrating. 
In MODE E this time can be utilized, thus Increasing the 
system throughput. For this application the time gained 
is used to continue printing, in other applications, such 
as a disk controller, It could be used in data cacheing, 
overlapped seeks, etc. 

In MODE E arbitration the EASIODR must be written with 
the SCSIID and parity checking cancelled in the EASIMR2. 
The interrupts are set to allow selection and arbitration inter- 
rupts, with the jump table loaded with servaO. This sets a 
flag to show an interrupt has occurred. The enhanced arbi- 
tration is initiated, with a write to the arbitration bit of the 
EASIEMR. This causes the EASI to w ait fo r a Bus Free 
Phase; delay a Bus Free Delay; assert BSY and the EA- 
SIODR; delay an Arbitration Delay then interrupt the proces- 
sor. The interrupt causes the flag to be set that shows the 
state of arbitration should be examined. While waiting for 
this interrupt the printer carries on printing out data, until 
front equals rear. 

After the interrupt is detected the EASIISR can be read to 
determine the cause. If it is not an arbitration interrupt parity 
checking is enabled and the interrupt treated as a selection, 
by calling main(). If the intermpt is signalling the com- 
mencement of arbitration, the procedure is the same as in 
MODE N, with the LA bit of the EASIICR being examined, 
and priority determined by reading the EASICSD. If arbitra- 
tion is lost, interrupts must be reset, the arbitration bit in the 
EASIEMR reset, and the whole procedu re be gun again. If 
arbitration is successful the user asserts SEL. 
Function printarb() is used to print data during arbitration in 
the same way as printitO does normally. The difference 
here is that the arbitration interrupt should be serviced as 
quickly as possible. 

This routine must be left If an interrupt occurs. Instead, of 
waiting for the printer to come on-line if an error occurs this 
routine simply does not send the character. 
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4.0 Run-Time Software (continued) 

4.6.3 Reselection 

When arbitration has been won the disconnected initiators 
ID and command block must be restored, and the initiator 
reselected. This reselection is carried out by function rese- 
lectO. 

The EASISER is cleared to stop it responding to the rese- 
lection and the Initiator ID bit written into the EASIODR 
along with the SCSIID. I/O must be asserted to show this is 
a reselection. The EASIODR is asserted onto the bus and 
the releva nt arb itration bit, depending on MODE reset. This 
deasserts BSY. Parity checking is enabled, and the board 
waits a selection time out de lay of 250 ms for th e initiator to 
respond, by asserting BSY. If it does not, RST is asserted, 
resetting the whole SCSI bus. 

If the initiator does respond, the target must assert BSY, 
then deassert SEL and take the EASIODR off the bus. For 
MODE E the interrupt mask can be set, and the arbitration 
interrupt reset. Reselection is now complete. 

4.6.4 Reconnection 

After reselectO the IDENTIFY message is sent by the target 
with the disconnect bit set. The command that was previ- 
ously sent is processed, if this message is received suc- 
cessfully. After processing the command status and the 
COMMAND COMPLETE message are retur ned. resetO is 
again used to set the interrupts and release BSY. 
If a print was not current at the time of reconnection, and 
the reconnected command was PRINT, this is handled with- 
in reconnectf). As long as the status is GOOD the print is 
carried out. However, reconnect() will be mostly called from 
outbufO, when the queue has enough free space to pro- 
cess the outstanding command. Any reconnection missed 
by outbufO is captured in main(). 

4.7 ERROR HANDLING 

Throughout this document the handling of errors has been 
discussed as the en'ors arose, but there are some remaining 
to be discussed. These are phase or parity errors during 
command transfers and message errors. 

4.7.1 General Error Handling 

While this board is connected to the SCSI bus, with BSY 
active, gen_int() is generally used to handle interrupts. 
This routine responds to an unexpected interrupt by check- 
ing the parity and phase flags, in the EASIBSR for MODE N, 
the EASIISR for MODE E. It then resets the interrupts, be- 
fore setting appropriate flags. Sense is set to ABORTED 
COMMAND with a status of CHECK CONDITION if an error 
has occurred. 

After calling select(), to respond to selection, main() then 
calls function set_up(), which sets the mask and jump ta- 
ble to respond t o an interrupt. This is also the routine which 
checks to see if ATM is asserted. If it is getmes() is called to 
enter the Message Out phase and fetch the IDENTIFY mes- 
sage. messoutO processes the message. This is where the 
target determines if the initiator supports disconnection. 
If an error occurs during select() or set-up(), detected by 
gen_int(), the board sends relevant status and a message 



of COMMAND COMPLETE, before releasing the bus. No 
attempt is made to recover from the error. Similarly, if a 
phase en-or occurs during the command phase, status and 
sense are returned. However, if a parity error occurs during 
a command phase, the target can attempt a recovery by 
sending the RESTORE POINTERS message. This message 
instructs the initiator to reset the command pointer to the 
beginning of the command block, allowing the target to re- 
enter the Command Out phase and re-transfer the com- 
mand block. If there is a parity error again, status is re- 
turned, along with the COMMAND COMPLETE message. If 
the second transfer is successful, the command execution 
continues as normal. 

4.7.2 Message Errors 

If an initiator wishes to respond to a mes sage sent by the 
targe t it indicates this by asserting ATN, before releasing 
ACK to finish the transfer. The target should then ente r the 
Message In phase, and transfer message bytes until ATN 
goes Inactive, up to 256 bytes. If the initiator attempts to 
send more than this the target will send the MESSAGE RE- 
JECT message and terminate the command with status of 
CHECK CONDITION and sense set to ABORTED COM- 
MAND. If a parity error occurs during the message transfer, 
the target must wait until the transfer is complete, then in- 
stnjct the initiator to resend all previous message bytes, by 
asserting REQ before changing phase. If the parity error 
occurs again the command will be terminated with status of 
CHECK CONDITION and sense ABORTED COMMAND. 
The relevant functions for message phases are messin(), 
getmesO and messout(). messin() is used to send a mes- 
sage to the initiator, while getmesO fetches a message 
from the initiator. messout() processes the message sent 
by the initiator. The supported messages are now explained. 
IDENTIFY: establishes the use of a greater message set, 
indicates the ability to support, or not support, disconnection 
and gives a LUN number, if necessary. 
ABORT: if the reserving Initiator sends this message to the 
target it causes the board to be reset. 
BUS DEVICE RESET: This is similar to ABORT, except any 
initiator can implement it, resetting the board. 
MESSAGE PARITY ERROR: On receiving this message the 
target attempts to resend the last message sent, and if this 
fails, terminates the command with status of CHECK CON- 
DITION and sense set to HARDWARE ERROR. 
MESSAGE REJECT: the targets response to this message 
is determined by the message being rejected. If the last 
message sent was COMMAND COMPLETE, the MESSAGE 
REJECT is ignored, since the initiator must support the 
mandatory message. A MESSAGE REJECT in reply to a 
DISCONNECT causes the disconnection to be cancelled. If 
it was in reply to a MESSAGE REJECT sent, the command 
is terminated with a status of CHECK CONDITION and 
sense set to HARDWARE ERROR. If the message sent was 
IDENTIFY (during reconnection) the target immediately 
goes to the Bus Free Phase and aborts the command. No 
Status or Message In phases are attempted, though sense 
is set to HARDWARE ERROR. 
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4.0 Run-Time Software (continued) 

It should be noted that messInO has been written to only 
allow getmesO to be called, from Inside messln(), once. 
Alternatively on parity error the target and Initiator could 
eternally cycle, sending each other the MESSAGE PARITY 
ERROR message. 

4.7.3 Non-Recoverable Errors 

The following are errors which occur during selection, so 
severe that system operation Is terminated, with an en'or 
code displayed on the LED. 
The first two concern a DP5380. 
En-or4 

Wrong Interrupt flags active. 
Error 5 

SEL inactive. 
These en-ors concern either a DP5380 or a DP8490. 
Error 6 

SCSIID bit not active on bus. 
En'or 7 

More than two bits active on bus. 
The final errors are for a DP8490 only. 
Error 8 

SCSI parity error. 
Error 9 

Select flag Inactive. 

5.0 User Guide 

The SCSI Printer Controller (SPC) Is a Small Computer Sys- 
tem Interface target board, which can use either the 
DP5380 Asynchronous SCSI Interface (ASI) or DP8490 En- 
hanced Asynchronous SCSI Interface (EASI). It can be se- 
lected and used by an Initiator as described In the 
ANSX3.131 '!986 SCSI standard as defined by the ANSI 
X3T9.2 committee. This document will explain the installa- 
tion of SPC, and show how it can be used In a system. By 
way of example a description Is given of how the SPC can 
be used with an Advanced Storage Concepts ASC-88 IBM 
PC-SCSI Manager IItm host adaptor. 

5.1 INSTALLATION 

This section explains how the board must be set up before 
use, and the type of connectors required to interface to it. 
Any reference made to an EASI also applies for an ASI. 



5.1.1 POWER 

The SPC can be installed in a Personal Computer (PC) 
where it takes power from the backplane. There are two 
connections to + 5V and two to ground. These are the only 
connections made to the backplane. Alternatively power 
can be taken from the available connector block (Figure 
S.I). 

When the board receives power the LED will come on, and 
stay on If the board passes its self diagnostics. If it falls an 
en-or message will be displayed by the LED, indicating the 
source of error. This will be further explained in section 
5.1.5. If the LED does not come on some fatal en-or has 
occurred. 

5.1.2 SCSI CONNECTOR 

The SCSI bus should consist of a 50 way flat ribbon cable a 
maximum of 6.0 meters long. Both ends of this cable should 
have all SCSI lines terminated, with a 330n resistor to 
ground and a 220(1 resistor to power. SCSI devices are 
daisy chained along this cable, with SCSI signals common 
to all devices. 

The SPC contains sockets for two DP8490 or DP5380 de- 
vices, one a PLCC socket the other OIL. Only one of these 
sockets should contain a device; 
To comply with the regulations on terminating resistors six 
SIL resistor packs are available between the SCSI connec- 
tor and the EASI DIL package (Figure 5. 1). If this board is 
not to be used at the end of the SCSI cable all of these six 
packs must be removed. The resistors have been socketed 
for this purpose. 

An option available In the SCSI standard is to supply termi- 
nator power on the cable, so terminators at either end of the 
bus can use the same power, if the device at one end of the 
bus Is unpowered Its terminators can receive power from 
the cable, and the bus will operate correctly. It should be 
noted that other manufacturer's CMOS devices will not work 
In this configuration since if not powered they pull the SCSI 
lines low. National Semiconductor's DP5380 and DP8490 
have special input protection to prevent this. 
Pin 26 on the SCSI connector Is the terminator power pin, 
which can be left floating by leaving the jumper in position 2, 
see Figure 5.2. By moving the jumper to position 1 the termi- 
nator power Is supplied to this pin. Figure 5.3 shows the two 
possible configurations. Terminator power Is fed through a 
Schottky barrier diode to prevent a backflow of power Into 
the board. 



SCSI 
conntctor 













4321 


LED 








link 

D 


♦ 

1 |po*w 




U 1 




n 


EASI 
PLCC 


swKchw 






EASI 
DIP 






^^^ 




_l 



printtr 
coiintctor 



SCSI 
ttrminators 



TL/F/100e2-6 



FIGURE 5.1 



4-96 



5.0 User Guide (continued) 



LINK 



> 
Z 

di 
at 
w 



jumper 



X X 

X X 

X X 



jumper 



Position 1 Position 2 

FIGURE 5.2 



>h 



22(Ul 



position 2 



position 



>n l\^ 



>■ Pin 26 of SCSi 

connector 

floating 



■> All SCSI lines 



330a 



TL/F/10O82-7 



FIGURE 5.3 



5.1.3 SWITCH BLOCK SETTINGS 

The switch block is included to allow the user to select the 
SCSI ID of the SPC. This is used to identify the board during 
selection phases and determine its priority in arbitration. 
The SCSI ID Is read in as a three bit binary number and 
converted in software to an eight bit pattern, with one bit 
active. For an ID of the least significant bit is active, for an 
ID of 7 the most significant bit Is active. 
The three bit number is tal<en from the switch block (see 
Figure 5. 1 ), using switches 1 , 2 and 3. 1 is the most signifi- 
cant bit, 4 is unused. These switches should be set to give a 
unique ID for this bus. An ID of is suggested, making the 
printer the lowest priority device on the bus. These switches 
must be set up before power is applied, as they are only 
checked during the board diagnostics. 

5.1.4 PRINTER CONTROLLER 

The printer connector is a standard IBM 25 way 'D' type 
connector. The SPC softwa re controls data transfers to the 
printer using the BUSY and STROBE signals. 

5.1.5 ERROR MESSAGES 

Non-recoverable errors cause a four bit binary number to be 
displayed by the LED. This indicates the source of error. 
The LED displays the number by occulting for 1 second to 
show a 1 , Vz second to show a 0. The code Is displayed 
most significant bit first, with the LED on for 1 second be- 
tween bits. The error number is repeatedly displayed, be- 
tween breaks of 2 seconds when the LED is on. 
The error numbers, and their cause, are shown below. The 
first four en-ors are generated during the board diagnostics, 
the others occur when a selection fails. The SCSI controller 
will be referred to as an EASI, unless the error is specific to 
either a DP5380 or DP8490. These possible differences are 
due to the DP8490's more extensive testing, and because it 
handles a selection differently. 
Error 

The DI\/IA could not be accessed. This is possibly a dam- 
aged device. 



Error 1 

EASI can not be accessed. Device could be damaged, or 
not properly terminated. 
Eri-or 2 

OP8490 has failed loopback test. Device could be dam- 



Error 3 

DP8490 has failed the loopback DMA test. In this test a 
DMA transfer to memory from the DP8490 Is attempted. 
Failure here could indicate an en-or in memory, processor, 
DMA, DP8490 or PALs. 

These first four errors concern problems internal to the 
board. The following errors indicate a bus problem that oc- 
curred while the board was waiting for selection. 
Error 4 

DP5380 en-or flag active. 
Error 5 

DP5380 found select line inactive. Possible selection 
timeout or bus error. 
En-or 6 

EASI ID bit not active on bus. Possible selection timeout 
or bus error. 
Error 7 

EASI detected more than two bits active on bus. During a 
selection phase the initiator can only assert its own ID and 
the targets ID on the bus. This indicates a bus error. 
Error 8 

DP8490 SCSI parity error. Error on bus. 
Error 9 

DP8490 select flag inactive. This is board hardware error, 
possibly in DP8490 or PAL, possibly interrupt line. 
For any of these problems the user should try switching the 
device on and off again. For bus errors the cable and termi- 
nators should be checked along with any other devices on 
the bus. 
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5.0 User's Guide (Continued) 
5.2 DRIVER SOFTWARE 

By way of example It will be shown how software can be 
written to drive the SPC from an ASC-88 host adaptor, In- 
stalled In a PC. The ASC-88, like many commercially avail- 
able host adaptors, handles all low level SCSI signal con- 
trols. The user controls the command to be implemented by 
means of a Job Control Block, JCB, which Is passed to It. 
The software required to use an ASC-88 Is on the supplied 
floppy disk. This disk contains both the source code, ex- 
plained later, and the executable code. This is called 
printoutexe and can be implemented In the form: 

printout filename 
The filename supports the MS-DOS use of directories and 
paths: 

e.g., printout a: /ASC /ASC.C 

The second executable command, called stoprlntexe, can 
be used to terminate a print. When this command is execut- 
ed the SPC flushes the print queue and initializes the printer. 

5.2..1 SEQUENCE OF COMMANDS 

Although the SPC requires no prescribed sequence of SCSI 
commands an initiator must reserve the unit before a 
print can tai(e piace. Othenwise the sequence of com- 
mands specified here indicate how the SPC could be used. 
Any print Should begin with a TEST UNIT READY com- 
mand. On receiving this command the SPC tests the printer 
to ensure it has paper and Is not in an error condition. If the 
status of GOOD is returned the user should then attempt 
RESERVE UNIT. If the command is successful the SPC will 
only execute commands from this Initiator. This prevents 
print data from two or more sources being mixed. 
The user then sends PRINT commands with a maximum 
length of data per transfer of 2 kB. If the file to be printed Is 
larger than 2 kB the data must be sent in several blocks. 
This limit, set to minimize bus latency. Is more fully ex- 
plained in Section 4.4.3. 

These PRINT commands transfer the data to the SPC print 
buffer. To check if an error occurred when the SPC attempt- 
ed to transfer the data to the printer the user can send a 
REQUEST SENSE command. If the returned data Is NO 
SENSE the printer is still operational. Any other sense Indi- 
cates an error. 

The final command sent is RELEASE UNIT. This allows the 
SPC to be used by other initiators. 



5.2.2 ASC-88 SOFTWARE 

All ASC-88 software Is written for a Microsoft® C compiler. 
File ASC.C contains the main run-time software. ASC 
STRUC.LIB sets up the structure which is used as a Job 
Control Block, while ASCCOM.LIB defines the JCBs for par- 
ticular SCSI commands. The routines used in ASC.C, other 
than SCSI command calls, are in ASCROT.LIB and 
UTIL.LIB. CONSTANT.H contains the constants used 
throughout these files. If the user wishes the SCSI ID of the 
target board to be anything other than zero they should 
change the value of TARGET_ID In this file, and recompile 
the code for both commands. 

STDIO.H Is a Microsoft library containing constants, macro 
definitions and function declarations for I/O stream opera- 
tions. This controls opening files, reading files, detecting file 
ends and closing files. DOS.H, also a Microsoft library, han- 
dles the interface to MS-DOS®. This allows the user to set 
up registers and execute internjpts. The final Microsoft li- 
brary CONIO.H allows the user to fetch information from the 
keyboard. 

The SCSi-BIOSTM EPROM In the ASC-88 is accessed by 
generating inten'upt number forty. The value In the 'AH' reg- 
ister determines what SCSI-BIOS software is used. SCSI- 
PRO™ Implements the SCSI command specified In the JCB 
whose starting address Is passed in the 'BX' and 'ES' regis- 
ters. 

ASC.C must be compiled and loaded to produce a file print- 
out.exe. When executed this code opens the file specified in 
the command line and Instigates the sequence of com- 
mands, outlined in the previous section, to print It out. After 
these commands the file is closed. 
If the printer enters an error state while communicating with 
the Initiator a message will be displayed on screen and the 
user is given the option of terminating the print. If the print Is 
to be continued the user must correct the printer error and 
press a key to restart the print, if an error occurs when the 
SPC has already received ail the data from the PC the board 
will wait until the print error is corrected and continue print- 
ing. 

STOPRINT.C contains the run-time software required to ter- 
minate a print. This uses the library CHECK.LIB, which 
checks the success of a FLUSH BUFFER command. To 
terminate an unwanted long print the user can: take the 
printer off-line; press escape to leave printout, send the 
stoprint command. 
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